¿Puedo acceder a variables desde otro archivo?

178

¿Es posible usar una variable en un archivo llamado first.jsdentro de otro archivo llamado second.js?

first.jscontiene una variable llamada colorcodes.

SAK
fuente
@Roki: Por ejemplo, podría estar cargando datos de otro sitio web, mientras que el script para procesarlos está en su sitio:<script src="http://datasource.example.net/first.js"></script><script src="second.js"></script>
Piskvor salió del edificio el
el sitio del origen de datos no tiene una devolución de llamada? lo que quiero decir: descargar second.js contiene: ... function segundoscriptFn (o) {// hacer algo / w datos; } ... descargue datasource.example.net/first.js?callback=secondscriptFn y luego primero contenga: secondscriptFn ({back: "# fff", front: "# 888", side: "# 369"}); más controlable y robusto que las versiones de alcance global, porque puede controlar el alcance first.js ...
Roki
44
Solo como una nota si está utilizando jQuery y está tratando de hacer esto. Debe asegurarse de no colocar la variable a la que intenta acceder desde el primer archivo en la función '$ (documento) .ready ()'; de lo contrario no se cargará correctamente, al menos desde mi experiencia.
Collin McGuire

Respuestas:

195

Como dijo Fermín, una variable en el ámbito global debería ser accesible para todos los scripts cargados después de que se declare. También puede usar una propiedad de windowo (en el ámbito global) thispara obtener el mismo efecto.

// first.js
var colorCodes = {

  back  : "#fff",
  front : "#888",
  side  : "#369"

};

... en otro archivo ...

// second.js
alert (colorCodes.back); // alerts `#fff`

... en su archivo html ...

<script type="text/javascript" src="first.js"></script> 
<script type="text/javascript" src="second.js"></script> 
Dagg Nabbit
fuente
55
En un navegador, window es el alcance global, por lo que window.colorCodes y el objeto (global) colorCodes es el mismo objeto.
Piskvor salió del edificio el
Es cierto ... la razón por la que lo menciono es para casos en los que necesita establecer una variable global desde un ámbito no global.
Dagg Nabbit
2
¿Qué pasa con HTML? en html tengo: <script>var variable1 = true;</script> <script src="first.js"></script>¿first.js verá esa variable? Lo probé en la extensión de Google Chrome y no funcionó
user25
@ user25, tengo el mismo problema, ¿encontraste una solución?
Mercurio
2
Si está utilizando eslint, puede agregar /* global colorCodes */en la línea de arriba para evitar el mensaje de error "... no está definido"
Joseph K.
41

Puede exportar la variable desde el primer archivo usando exportar .

//first.js
const colorCode = {
    black: "#000",
    white: "#fff"
};
export { colorCode };

Luego, importe la variable en el segundo archivo usando import .

//second.js
import { colorCode } from './first.js'

exportación - MDN

Germa Vinsmoke
fuente
14

Me gustó lo que dijo la respuesta anterior pero, aunque no funcionó conmigo

porque yo era declaringestas variables insideJQuery$( document ).ready()

así que asegúrese de declarar sus variables dentro de la <script>etiqueta, no en otro lugar

Basheer AL-MOMANI
fuente
13

Esto debería funcionar: defina una variable global en el primer archivo y acceda desde el segundo archivo:

<script src="/firstfile.js"></script>
<script src="/secondfile.js"></script>

firstfile.js:

var colors = {
   text:'#000000',
   background:'#aaaaaa',
   something_else:'blue'
};

secondfile.js:

do_something_with(colors.background);

Tenga en cuenta que el orden en el que carga los archivos de script es significativo para algunos navegadores (IE6 seguro, tal vez otros)

Piskvor salió del edificio
fuente
1
Es posible que deba adjuntar esa variable al objeto como: this.colors = colors. Si es un objeto en lugar de una enumeración, puede hacer una función para devolver el valor. this.getTextColor = function () {return colors.text; };
aggaton
1
¿Cómo actualizaría una variable desde una página cargada? <script type = "text / javascript"> colors.background = "nueva columna"; </script> no parece funcionar.
v3nt
6

Usando Node.js puede exportar la variable a través del módulo.

//first.js
const colorCode = {
    black: "#000",
    white: "#fff"
};
module.exports = { colorCode };

Luego, importe el módulo / variable en el segundo archivo usando require.

//second.js
const { colorCode } = require('./first.js')

Puede usar el importy el exportacercamiento desde ES6 usando Webpack / Babel, pero en Node.js necesita habilitar un indicador, y usa la extensión .mjs.

Xinton
fuente
3

Me encontré con amplify.js . Es realmente simple de usar. Para almacenar un valor, llamémosle "myValue", usted hace:

amplify.store("myKey", "myValue")

Y para acceder, lo haces

amplify.store("myKey")
Ben Leitner
fuente
2

Si almacena sus códigos de color en una variable global, debería poder acceder a ellos desde cualquier archivo javascript.

Fermín
fuente
2

Puede que esté haciendo esto un poco diferente. No estoy seguro de por qué uso esta sintaxis, la copié de algún libro hace mucho tiempo. Pero cada uno de mis archivos js define una variable. El primer archivo, sin ningún motivo, se llama R:

    var R = 
    { 
        somevar: 0,
        othervar: -1,

        init: function() {
          ...
        } // end init function

        somefunction: function(somearg) {
          ...
        }  // end somefunction

        ...

    }; // end variable R definition


    $( window ).load(function() {
       R.init();
    })

Y luego, si tengo un gran fragmento de código que quiero segregar, lo pongo en un archivo separado y un nombre de variable diferente, pero aún puedo hacer referencia a las variables y funciones de R. Llamé al nuevo TD sin ninguna buena razón:

    var TD = 
    { 
        xvar: 0,
        yvar: -1,

        init: function() {
           ...
        } // end init function

        sepfunction: function() {
           ...
           R.somefunction(xvar);
           ...
        }  // end somefunction

        ...

    }; // end variable TD definition


    $( window ).load(function() {
       TD.init();
    })

Puede ver que en la 'sepfunción' de TD llamo a la función R. Me doy cuenta de que esto no brinda ninguna eficiencia de tiempo de ejecución porque ambos scripts deben cargarse, pero me ayuda a mantener mi código organizado.

Alan
fuente
0

Una mejor manera es mediante el uso de la ventana. ESTADO INICIAL

<script src="/firstfile.js">
    // first.js
    window.__INITIAL_STATE__ = {
      back  : "#fff",
      front : "#888",
      side  : "#369"
    };
</script>
<script src="/secondfile.js">
    //second.js
    console.log(window.__INITIAL_STATE__)
    alert (window.__INITIAL_STATE__);
</script>
Karan Shaw
fuente
¿Cuál es la ventaja de este enfoque sobre las otras respuestas?
Boric