search
HomeWeb Front-endJS TutorialDetailed explanation of js array operations_javascript skills

I have been using js for a long time, but I have never delved into the array form of js. Occasionally, just use simple string.split(char). A project I worked on during this period used arrays in many places. I thought I was a master of JS but I couldn’t start with it. I’ll learn from you! hehe. After learning it, I realized that js arrays are very powerful, much more powerful than VB and C#. Let’s take a look

1. Creation of array

Copy code The code is as follows:

var arrayObj = new Array(); //Create one Array
var arrayObj = new Array([size]); //Create an array and specify the length. Note that it is not the upper limit, but the length
var arrayObj = new Array([element0[, element1[, ...[ , elementN]]]]); //Create an array and assign values ​​

It should be noted that although the second method creates an array and specifies the length, in fact the array is variable-length in all cases, which means that even if the length is specified to be 5, the elements can still be stored at the specified length. Otherwise, please note: the length will change accordingly.

2. Access to array elements

Copy code The code is as follows:

var testGetArrValue=arrayObj[1]; //Get the array The element value
arrayObj[1]= "This is the new value"; //Assign a new value to the array element

3. Adding array elements

Copy code The code is as follows:

arrayObj. push([item1 [item2 [. . . . [itemN ]]]]);//Add one or more new elements to the end of the array and return the new length of the array
arrayObj.unshift([item1 [item2 [. . . [itemN ]]]]); // Start by adding one or more new elements to the array, the elements in the array are automatically moved back, and the new length of the array is returned
arrayObj.splice(insertPos,0,[item1[, item2[, . . . [,itemN ]]]]);//Insert one or more new elements into the specified position of the array. The element at the insertion position is automatically moved back and "" is returned.

4. Deletion of array elements

Copy code The code is as follows:

arrayObj.pop(); //Remove the last one element and return the element value
arrayObj.shift(); //Remove the first element and return the element value, the elements in the array are automatically moved forward
arrayObj.splice(deletePos,deleteCount); //Delete from Specifies the number of deleteCount elements starting from deletePos at the specified position, and returns the removed elements in array form

5. Interception and merging of arrays

/ /Return a part of the array in the form of an array. Note that the element corresponding to end is not included. If end is omitted, all elements after start will be copied

arrayObj.concat([item1[, item2[, . . . [,itemN]] ]]); //Concatenate multiple arrays (can also be strings, or a mixture of arrays and strings) into one array, and return the connected new array




Copy code

The code is as follows:

arrayObj.slice(0); //Return the array Copy the array, note that it is a new array, not pointing to

arrayObj.concat(); //Return the copy array of the array, note that it is a new array, not pointing to




Copy code

The code is as follows:

arrayObj.reverse(); //Reverse elements ( The first one goes to the end, the last one goes to the front), returns the array address

arrayObj.sort(); // Sort the array elements, returns the array address




Copy code

The code is as follows:


arrayObj.join(separator); //Returns a string that connects each element value of the array together, separated by separator.
toLocaleString, toString, valueOf: can be regarded as special usage of join, not commonly used

2. Three attributes of array objects

1. length attribute

The Length attribute represents the length of the array, that is, the number of elements in it. Because the index of an array always starts from 0, the upper and lower limits of an array are: 0 and length-1 respectively. Unlike most other languages, the length property of JavaScript arrays is variable, which requires special attention. When the length attribute is set larger, the state of the entire array does not actually change, only the length attribute becomes larger; when the length attribute is set smaller than the original, the elements in the original array with indexes greater than or equal to length will All values ​​are lost. The following is an example demonstrating changing the length attribute:

Copy code The code is as follows:

var arr=[12,23,5,3, 25,98,76,54,56,76];
//Defines an array containing 10 numbers
alert(arr.length); //Displays the length of the array 10
arr.length =12; //Increase the length of the array
alert(arr.length); //Display that the length of the array has become 12
alert(arr[8]); //Display the value of the 9th element , is 56
arr.length=5; //Reduce the length of the array to 5, elements with indexes equal to or exceeding 5 are discarded
alert(arr[8]); //Show that the 9th element has been Becomes "undefined"
arr.length=10; //Restore the array length to 10
alert(arr[8]); //Although the length is restored to 10, the 9th element cannot be recovered , displays "undefined"

From the above code we can clearly see the nature of the length attribute. But the length object can not only be set explicitly, it may also be modified implicitly. You can use an undeclared variable in JavaScript. Similarly, you can also use an undefined array element (referring to an element with an index greater than or equal to length). In this case, the value of the length attribute will be set to the value of the element index used. Add 1. For example, the following code:

Copy code The code is as follows:

var arr=[12,23,5,3, 25,98,76,54,56,76];
alert(arr.length);
arr[15]=34;
alert(arr.length);

The code also first defines an array containing 10 numbers. It can be seen from the alert statement that its length is 10. Then the element with index 15 is used and assigned a value of 15, that is, arr[15]=34. At this time, the alert statement is used to output the length of the array, and the result is 16. Regardless, this is a surprising feature for developers accustomed to strongly typed programming. In fact, the initial length of an array created using new Array() is 0. It is the operation of undefined elements that causes the length of the array to change.
As you can see from the above introduction, the length attribute is so magical. You can use it to easily increase or decrease the capacity of the array. Therefore, an in-depth understanding of the length attribute will help to use it flexibly during the development process.

2. prototype attribute

Returns a reference to the prototype of the object type. The prototype property is common to object.
objectName.prototype
objectName parameter is the name of the object object.

Description: Use the prototype attribute to provide a set of basic functions of the object's class. New instances of an object "inherit" the operations assigned to the object's prototype.
For array objects, the following example illustrates the use of the prototype attribute.
Add a method to the array object that returns the maximum element value in the array. To accomplish this, declare a function, add it to Array.prototype, and use it.

Copy code The code is as follows:

function array_max()
{
var i,
max = this[0];
for (i = 1; i {
if (max max = this[i];
}
return max;
}
Array.prototype.max = array_max;
var x = new Array(1, 2, 3, 4, 5, 6);
var y = x.max();

After this code is executed, y holds the maximum value in the array x, or say 6.

3. constructor attribute

represents a function that creates an object.
object.constructor //object is the name of the object or function.

Description: The constructor property is a member of all objects with prototype. They include all JScript native objects except Global and Math objects. The constructor property holds a reference to the function that constructs a specific object instance.

For example:

Copy code The code is as follows:

x = new String("Hi");
if (x.constructor == String) // Process (condition is true).

or

Copy code The code is as follows:

function MyFunc {
// Function body.
}

Copy code The code is as follows:

y = new MyFunc;
if (y. constructor == MyFunc) // Process (condition is true).

For arrays:

Copy code The code is as follows:

y = new Array ();
Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
es6 数组怎么移除元素es6 数组怎么移除元素Jan 11, 2023 pm 03:51 PM

方法:1、用shift()删除第一个元素,语法“数组.shift()”;2、用pop()删除最后一个元素,语法“数组.pop()”;3、用splice()删除任意位置的元素,语法“数组.splice(位置,个数)”;4、用length删除尾部的N个元素,语法“数组.length=原数组长度-N”;5、直接赋予空数组“[]”来清空元素;6、用delete删除指定下标的一个元素。

js获取数组长度的方法js获取数组长度的方法Jun 20, 2023 pm 05:33 PM

在 JS 中获取数组长度非常简单,每个数组都有一个 length 属性,该属性返回数组的最大长度,即其值等于最大下标值加 1。由于数字下标必须小于 2^32-1,所以 length 属性最大值等于 2^32-1。下面代码定义了一个空数组,然后为下标等于 100 的元素赋值,则 length 属性返回 101。因此,length 属性不能体现数组元素的实际个数。

javascript如何将字符串转为数组javascript如何将字符串转为数组Nov 23, 2022 pm 07:28 PM

3种转换方法:1、使用split(),可将给定字符串拆分为字符串数组,语法“str.split(分隔符,数组最大长度)”;2、利用扩展运算符“...”,可迭代字符串对象,将其转为字符数组,语法“[...str]”;3、使用Array.from(),可将字符串转为数组,语法“Array.from(str)”。

js数组可以转化成php数组吗js数组可以转化成php数组吗Jun 02, 2023 am 10:06 AM

js数组可以转化成php数组,其操作方法是:1、建立php示例文件;2、使用语法“JSON.stringify()”将js数组转化为JSON格式的字符串;3、使用语法“json_decode()”将JSON格式字符串转为PHP数组,此处添加了参数true,表示将JSON格式字符串转换成PHP关联数组。

js数组删除某个元素有几种方法js数组删除某个元素有几种方法Aug 02, 2023 am 10:09 AM

js数组删除某个元素有4种方法,分别是:1、使用splice;2、使用filter;3、使用pop方法和shift;4、使用delete关键字。

JS数组排序:sort()方法怎么用JS数组排序:sort()方法怎么用Dec 27, 2023 pm 03:40 PM

JavaScript的Array.prototype.sort()方法用于对数组的元素进行排序。此方法是就地排序,也就是说,它修改原始数组,而不是返回一个新的排序数组。默认情况下,sort()方法按照字符串Unicode码点值进行排序。这意味着它主要用于字符串和数字的排序,而不是用于对象或其他复杂数据类型的排序。

JavaScript怎么求数组长度和元素之和JavaScript怎么求数组长度和元素之和Sep 20, 2022 pm 02:11 PM

JavaScript中,可利用length属性来获取数组长度,语法“数组对象.length”;可使用reduce()或reduceRight()函数来求元素之和,语法“arr.reduce(function f(pre,curr){return pre+cur})”或“arr.reduceRight(function f(pre,curr){return pre+cur})”。

js数组怎么转为php数组js数组怎么转为php数组Mar 22, 2023 am 11:24 AM

在web开发中,由于JavaScript(JS)和PHP是两种最为常用的编程语言,因此数组在开发过程中是不可避免的。针对这种情况,很多时候我们需要将JS数组转为PHP数组。实现这种功能的方法有很多,下面将一一介绍。

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Hot Tools

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.