JavaScript Array concat ()

El método JavaScript Array concat () devuelve una nueva matriz fusionando dos o más valores / matrices.

La sintaxis del concat()método es:

 arr.concat(value1, value2,… , valueN)

Aquí arrhay una matriz.

Parámetros concat ()

El concat()método toma un número arbitrario de matrices y / o valores como argumentos.

Valor de retorno de concat ()

  • Devuelve una matriz recién creada después de fusionar todas las matrices / valores pasados ​​en el argumento.

El concat()método primero crea una nueva matriz con los elementos del objeto en el que se llama al método. Luego agrega secuencialmente argumentos o los elementos de argumentos (para matrices).

Ejemplo 1: uso del método concat ()

 var languages1 = ("JavaScript", "Python", "Java"); var languages2 = ("C", "C++"); // concatenating two arrays var new_arr = languages1.concat(languages2); console.log(new_arr); // ( 'JavaScript', 'Python', 'Java', 'C', 'C++' ) // concatenating a value and array var new_arr1 = languages2.concat("Lua", languages1); console.log(new_arr1); // ( 'C', 'C++', 'Lua', 'JavaScript', 'Python', 'Java' )

Salida

 ('JavaScript', 'Python', 'Java', 'C', 'C ++') ('C', 'C ++', 'Lua', 'JavaScript', 'Python', 'Java')

Ejemplo 2: concatenación de matrices anidadas

El concat()método devuelve la copia superficial de los elementos concatenados de la siguiente manera:

  • Copia referencias de objetos a la nueva matriz. ( Por ejemplo : pasar una matriz anidada) Entonces, si se modifica el objeto referenciado, los cambios son visibles en la nueva matriz devuelta.
  • Copia el valor de cadenas y números en la nueva matriz.
 var randomList = (1, 2, 3); var randomNestedList = ( (4, 5), (6, 7), ); var combined = randomList.concat(randomNestedList); console.log(combined); // ( 1, 2, 3, ( 4, 5 ), ( 6, 7 ) ) // changing the value 1 to 0 randomList(0) = 0; console.log(randomList); // ( 0, 2, 3 ) // changes not reflected in concatenated array console.log(combined); // ( 1, 2, 3, ( 4, 5 ), ( 6, 7 ) ) // modifying nested list (adding 6 to first element) randomNestedList(0).push(6); console.log(randomNestedList); // ( ( 4, 5, 6 ), ( 6, 7 ) ) // changes are reflected in concatenated array // since it is a reference to the object console.log(combined); // ( 1, 2, 3, ( 4, 5, 6 ), ( 6, 7 ) )

Salida

 (1, 2, 3, (4, 5), (6, 7)) (0, 2, 3) (1, 2, 3, (4, 5), (6, 7)) ((1, 2 , 3), (6, 7)) (1, 2, 3, (4, 5, 6), (6, 7))

Aquí, la referencia de la matriz anidada se copia en la matriz concatenada. Entonces, cuando modificamos alguna de las referencias, los cambios se reflejan en todas partes.

Lecturas recomendadas:

  • JavaScript Array.pop ()
  • JavaScript Array.push ()

Articulos interesantes...