Rumah hujung hadapan web tutorial js 六种JS数组使用方法实例总结

六种JS数组使用方法实例总结

Jul 20, 2018 pm 03:20 PM
tatasusunan js

在js学习的过程中,js数组的方法的学习是必须要掌握的,这里我总结了一下js数组中常用的方法,大家相互学习一下。话不多说,让我们来直接进入到正文学习。

一、js对象继承的方法

数组是一种特殊的对象,继承了对象Object的toString()、toLocaleString()和valueOf()方法

1.toString()

toString方法返回由数组中每个值的字符串形式拼接而成的一个以符号分割的字符串于不使用参数的join()返回的字符串相同

[1,2,3].toString()//'1,2,3'
['a','b','c'].toString()//'a,b,c'
[1,[2,3]].toString()//'1,2,3'
Salin selepas log masuk

2.toLocaleString()

toLocaleString()是toString()的本地化版本,在常态下,和toString()返回一样,在数字到达3位数以上,为自动格式化、还可以格式化日期

var a = 3333; a.toLocaleString()//3,333
var b = new Date; b.toLocaleString()//2018/7/13 下午3:43:39
Salin selepas log masuk

3.valueOf()

valueOf()在对于数组对象的时候返回本身

var a = [1,2,3]; a.valueOf()//[1,2,3];
a.valueOf() instanceOf() Array//true
Salin selepas log masuk

二、js数组转换法

1.join()

Array.join()是Array.split()的逆向操作,前者是将数组以参数单位(默认为逗号)合并成一个字符串,后者是把字符串切割成数组。支持数组与类数组,不支持对象

var a = [1,2,3,4,5]; a.join()//'1,2,3,4,5'
var b = [1,undefined,2,null,3]; b.join()//'1,,2,,3'
var c = Array.prototype; c.join.call('hello','-')//'h-e-l-l-o'
var d = {1:'a',2:'b',length:3}; d.join()//'a,b'
var e = {1:'a',2:'b'}; e.join()//''
Salin selepas log masuk

三、js数组数据结构操作方法

数组的数据结构分为栈结构(后进后出)和队列结构(先进先出)

栈结构(后进后出):

1.push()

push()是把任意数量的参数逐个添加在末尾,改变原有数组,修改数组长度并返回

var a = [1,2]; a.push('11,22') - a//3 - [1,2,33,44]
var b = [3,4]; a.push([33.44]) - a//2 - [1,2,[33,44]]
Array.prototype.push.apply(a,b)//[1,2,3,4]
Array.prototype.push.call(a,b)//[1,2,[3,4]]
Salin selepas log masuk

push()也可以往对象中添加参数。添加后对象会变成数组对象,新加入的元素的键对应数组的索引,并且对象有一个length属性

var c = {}; Array.prototype.push.call(c,1)//{0:1,length:1}

2.pop()

pop()把数组中最后一项移除,返回数组长度、然后修改数组长度改变原有数组

var a = [1,2,3]; a.pop() - a//3 - [1,2];
//如果数组本身是空数组,则返回undefined
var b = []; b.pop()//undefined
Salin selepas log masuk

队列结构(前进前出):

1.shift()

shift()移除数组中第一项,返回移除的元素,然后修改数组长度改变数组

var a = [1,2,3]; a.shift() - a//1 - [2,3];
Salin selepas log masuk

2.unshift()

unshift()在数组的起始位置添加任意参数修改数组长度,返回数组长度改变数组

var a = [1,2,3]; a.unshift(4,5) - a//5 - [1,2,3,4,5]
Salin selepas log masuk

四、js数组排序方法

1.reverse()

reverse()用于反转数组的顺序,修改原数组,并返回当前数组

 var a = [1,2,4,3,5]; a.reverse()// [5,3,4,2,1];
Salin selepas log masuk

2.sort()

sort()默认情况下是改变数组为升序排序,sort会默认的调用每个数组项toString()

var a = [1,2,3,4,5]; a.sort() //[1,2,3,4,5]
var b = [1,2,12,13]; c.sort() //[1,12,13,2]
var c = [1,2,'1a','2b']; c.sort() //[1,'1a',2,'2b'];
Salin selepas log masuk

如果数组中含有undefined,则undefined会排到尾部

var d = [1,3,undefined,2]; d.sort() //[1,2,3,undefined]
Salin selepas log masuk

如果sort有参数的时候(参数必须是一个函数);如果函数return的值是正数或者第一个参数减去第二个参数,则为正序,否则为反序。如果存在字符串,则会为最小。按照顺序放到起始位置

function sortNumber(a,b){
  return b-a
}
var e = [1,2,3]; e.sort(sortNumber)//[3,2,1]; 
var f = ['1a',1,'2b',2,3]; f.sort()//['1a','2b',3,2,1];
Salin selepas log masuk

如果sort参数是函数返回的是一个随机正负数,则会随机数组书序

function sortRandom(a,b){
  return Math.random()-0.5
}
var g = [1,2,3,4,5]; g.sort(sortRandom)//[2,1,5,4,3](此为随机顺序)
Salin selepas log masuk

3.concat()

concat()方法是基于当前数组创建一个新数组然后把接收的参数放到末尾,不影响原数组

var a = [1,2]; b = [3,4]; a.concat - a//[1,2,3,4] - [1,2];五.创建子数组方法
Salin selepas log masuk

4.slice()

slice()方法截取参数第一位起始位置,和第二位终止位数。并创建一个新的数组。如果没有参数,那就是全部截取

var a = [1,2,3,4,5];a.slice(2,4)//[3,4,5]
var a = [1,2,3,4,5];a.slice(2)//[3,4,5]
var a = [1,2,3,4,5];a.slice(-3)//[3,4,5] 
var a = [3,4,5];a.slice()//[3,4,5]
Salin selepas log masuk

五.js数组删改方法

1.splice()

splice()接收三个参数,第一个参数是位置必填的,第二个参数是要删除的数量必填,如果只有一个参数,则全部删除数组、第二个参数以后都是是新增项目选填。返回的是被删除的数组

var a = [1,2,3]; a.splice(2,0,1)-a//[]-[1,2,1,3];
var b = [1,2,3]; a.splice(2,1,1)-a//[3]-[1,2,1];
var c = [1,2,3]; a.splice(2)-a//[1,2,3]-[]
var d = [1,2,3]; a.splice(2,1,4,5)-a//[3]-[1,2,4,5]
Salin selepas log masuk

2.indexOf()

indexOf()返回是第一个参数首次出现的位置,当有第二个参数n的出现的时候,返回的是,从第n个元素之前的元素不计算是否首次出现

var a = ['a','b','c',a,2,3]; a.indexOf('a')//0
var a = ['a','b','c',a,2,3]; a.indexOf('a',1)//4
var a = ['a','b','c',1,2,3]; a.indexOf('a',-5)//0
Salin selepas log masuk

3.lastIndexOf()

lastIndexOf()于indexOf()不同的就是:从右往左查

var a = ['a','b','c',a,2,3]; a.indexOf('a')//4
var a = ['a','b','c',a,2,3]; a.indexOf('a',1)//0
var a = ['a','b','c',a,2,3]; a.indexOf('a',-1)//0
Salin selepas log masuk

六.js数组归并的方法

1.reduce()

reduce()方法第一个参数是将指定的函数数组进行循环遍历以自定义的形式组合,生成单个值。参数接收四个(初始变量,当前变量,当前索引,原数组对象),reduce的第二个参数是指定一个参入的初始值。

var a = [1,2,3,4,5];
a.reduce(function(x,y){return x+y}) // 15
a.reduce(function(x,y){return x+y},3)//18
Salin selepas log masuk

2.reduceRight()

reduceRight()于reduce()不同在于索引值由高到低的

a.reduce(function(x,y){console.log(x,y);return x+y},0)
// 5,4 9,3 12,2 14,1 15,0
Salin selepas log masuk

七.js数组迭代方法

1.map()

map()给函数数组的每一项运行指定的的函数,并返回每次函数调用的结果组成数组

var a = [1,2,3]; a.map(function(item,index,arr){return item*2})
//[2,4,6]
var b = ['aa','bb','cc'];
a.map(function(item,index,b){return this[item]})
//['aa','bb','cc'];
Salin selepas log masuk

map()日常中多用于去解析对象中的属性

var c = {[name:1,value:2],[name:11,value:22]}
c.map(function(item){return item.name})//[1,11]
Salin selepas log masuk

2.forEach()

forEach()给函数数组的每一项运行指定的函数(于map()对比不同于没有返回值)。forEach()可接受第二参数,用来改变this的指向。

var a = {
    name:'111',
    arr:[1,2,3],
    value:function(){
        console.log(this);
        this.arr.forEach(function(){
        console.log(this);
        })
    }
}//循环外this指向value方法,循环内指向a对象
var b = {
  name:'111',
  arr:[1,2,3],
  value:function(){
    console.log(this);
    this.arr.forEach(function(){
      console.log(this);
    },this)
  }
}//全文的this全部都指向对象a
Salin selepas log masuk

3.filter()

filter()给函数数组的每一项运行指定的函数,并返回制定规则返回True的项的数组。该方法多用于查询,第二个参数值指定this指向

var a = [1,2,3];a.filter(function(item){return item>1)//[2,3];
Salin selepas log masuk

4.some()

filter()给函数数组的每一项运行指定的函数进行筛选,如果都返回false,则返回false。反之则返回true

a = [1,2,3,4,5];
a.some(function(item){return item === 3;})//true
a.some(function(item){return item === 6;})//false
Salin selepas log masuk

5.every()

every()给函数数组的每一项运行指定的函数进行筛选,如果有返回false,则返回false。反之如果全部返回true,则返回true;空数组会返回true

a = [1,2,3,4,5];
a.every(function(item){return item === 3;})//false
a.every(function(item){return item < 6;})//true
Salin selepas log masuk

相关推荐:

JS中数组重排序方法

js数组方法

Atas ialah kandungan terperinci 六种JS数组使用方法实例总结. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk mengalih keluar elemen dari tatasusunan es6 Bagaimana untuk mengalih keluar elemen dari tatasusunan es6 Jan 11, 2023 pm 03:51 PM

Kaedah: 1. Gunakan shift() untuk memadam elemen pertama, sintaksnya ialah "array.shift()"; 2. Gunakan pop() untuk memadam elemen terakhir, sintaksnya ialah "array.pop()"; Gunakan splice() untuk memadamkan Elemen di mana-mana kedudukan, sintaksnya ialah "array.splice(position, number)" 4. Gunakan panjang untuk memadam elemen N terakhir, sintaks ialah "array.length=original array length-N"; ; 5. Tetapkan tatasusunan kosong "[ ]" untuk mengosongkan elemen 6. Gunakan padam untuk memadamkan elemen pada subskrip yang ditentukan.

Bagaimana untuk menukar rentetan kepada tatasusunan dalam javascript Bagaimana untuk menukar rentetan kepada tatasusunan dalam javascript Nov 23, 2022 pm 07:28 PM

3 kaedah penukaran: 1. Gunakan split() untuk memisahkan rentetan yang diberikan kepada tatasusunan rentetan, sintaksnya ialah "str.split (pemisah, panjang maksimum tatasusunan)" 2. Gunakan operator pengembangan "... ", boleh diulang objek rentetan, tukarkannya kepada tatasusunan aksara, sintaks "[...str]" 3. Gunakan Array.from() untuk menukar rentetan itu kepada tatasusunan, sintaks "Array.from(str) ".

Bolehkah tatasusunan js ditukar kepada tatasusunan php? Bolehkah tatasusunan js ditukar kepada tatasusunan php? Jun 02, 2023 am 10:06 AM

Tatasusunan js boleh ditukar kepada tatasusunan php Kaedah operasi ialah: 1. Cipta fail sampel php 2. Gunakan sintaks "JSON.stringify()" untuk menukar tatasusunan js kepada rentetan dalam format JSON; Gunakan sintaks "json_decode()" "Tukar rentetan format JSON kepada tatasusunan PHP. Parameter benar ditambahkan di sini, yang bermaksud bahawa rentetan format JSON ditukar kepada tatasusunan bersekutu PHP.

Bagaimana untuk mendapatkan panjang tatasusunan dalam js Bagaimana untuk mendapatkan panjang tatasusunan dalam js Jun 20, 2023 pm 05:33 PM

Mendapatkan panjang tatasusunan dalam JS adalah sangat mudah Setiap tatasusunan mempunyai sifat panjang, yang mengembalikan panjang maksimum tatasusunan, iaitu nilainya bersamaan dengan nilai subskrip maksimum ditambah 1. Oleh kerana subskrip berangka mestilah kurang daripada 2^32-1, nilai maksimum atribut panjang adalah sama dengan 2^32-1. Kod berikut mentakrifkan tatasusunan kosong, dan kemudian memberikan nilai kepada elemen dengan indeks sama dengan 100, kemudian sifat panjang mengembalikan 101. Oleh itu, atribut panjang tidak boleh mencerminkan bilangan sebenar elemen tatasusunan.

Terdapat beberapa cara untuk memadamkan elemen daripada tatasusunan js Terdapat beberapa cara untuk memadamkan elemen daripada tatasusunan js Aug 02, 2023 am 10:09 AM

Terdapat 4 cara untuk memadam elemen daripada tatasusunan js, iaitu: 1. Gunakan splice;

Pengisihan tatasusunan JS: cara menggunakan kaedah sort(). Pengisihan tatasusunan JS: cara menggunakan kaedah sort(). Dec 27, 2023 pm 03:40 PM

Kaedah Array.prototype.sort() JavaScript digunakan untuk mengisih elemen tatasusunan. Kaedah ini disusun mengikut tempatnya, iaitu, ia mengubah suai tatasusunan asal dan bukannya mengembalikan tatasusunan diisih baharu. Secara lalai, kaedah sort() mengisih rentetan mengikut nilai titik kod Unicode mereka. Ini bermakna ia digunakan terutamanya untuk mengisih rentetan dan nombor, bukannya untuk mengisih objek atau jenis data kompleks lain.

Apakah kaedah untuk mengalih keluar pendua daripada tatasusunan js? Apakah kaedah untuk mengalih keluar pendua daripada tatasusunan js? Aug 09, 2023 pm 04:47 PM

Kaedah untuk menyahduplikasi tatasusunan js termasuk menggunakan Set, menggunakan indexOf, menggunakan termasuk, menggunakan penapis dan menggunakan mengurangkan. 1. Gunakan Set, yang dicirikan oleh fakta bahawa elemen dalam set tidak akan diulang 2. Gunakan indexOf untuk mengembalikan kedudukan indeks pertama elemen yang ditentukan dalam tatasusunan 3. Penggunaan termasuk untuk menentukan sama ada elemen sudah; wujud dalam tatasusunan 4. Gunakan penapis untuk menapis elemen 5. Gunakan pengurangan untuk memampatkan elemen dalam tatasusunan, dsb.

Bagaimana untuk mencari panjang dan jumlah elemen tatasusunan dalam JavaScript Bagaimana untuk mencari panjang dan jumlah elemen tatasusunan dalam JavaScript Sep 20, 2022 pm 02:11 PM

Dalam JavaScript, anda boleh menggunakan atribut panjang untuk mendapatkan panjang tatasusunan, sintaks ialah "objek.length tatasusunan" anda boleh menggunakan fungsi reduce() atau reduceRight() untuk mencari jumlah elemen, sintaksnya ialah "; arr.reduce(fungsi f(pra,curr){ return pra curr})" atau "arr.reduceRight(fungsi f(pra,curr){return pra curr})".

See all articles