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í arr
hay 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 ()