lo que preguntas, es un tema bastante amplio, existen dos tipos de pasajes de variables a una función.
Me remito a esta respuesta para citar:
Cuando es por valor, la información de la variable se almacenan en una
dirección de memoria diferente al recibirla en la funcion, por lo
tanto si el valor de esa variable cambia no afecta la variable
original, solo se modifica dentro del contexto de la función.
Cuando es por referencia, la variable que se recibe como parámetro en
la función apunta exactamente a la misma dirección de memoria que la
variable original por lo que si dentro de la función se modifica su
valor también se modifica la variable original.
Ahora, sabiendo esto, una función en JavaScript los tipos primitivos siempre son recibidos por valor en las funciones, mientras que los Array y objetos siempre serán recibidos por referencia
Vamos a un ejemplo:
function porValor(variable)
{
variable = "Nuevo valor!";
}
var variable = "Valor original!";
porValor(variable);
console.log(variable);
Como se puede ver, el contenido de variable
no se ve modificado, ahora vamos al ejemplo de un objeto
function porReferencia(objeto)
{
objeto.valor = "Nuevo valor!";
}
var objeto =
{
valor: "Original"
};
porReferencia(objeto);
console.log(objeto.valor);
En este ejemplo, se puede ver como el contenido del objeto objeto
se ve modificado.
Por último aclarar, que los objetos no pueden ser reasignados dentro de una función, sólo pueden modificarse sus propiedades.
En caso que el objeto sea reasignado (utilizando =
) el objeto original no será modificado, sino, una copia local dentro del scope de la función
function reAsignar(objeto)
{
var objeto =
{
valor : "No funciona!"
};
console.log(objeto.valor);
}
var objeto =
{
valor: "Original"
};
reAsignar(objeto);
console.log(objeto.valor);
Espero que quede claro el concepto, saludos