日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

javascript中数组的22种方法

發布時間:2023/12/18 javascript 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 javascript中数组的22种方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
前面的話數組總共有22種方法,本文將其分為對象繼承方法、數組轉換方法、棧和隊列方法、數組排序方法、數組拼接方法、創建子數組方法、數組刪改方法、數組位置方法、數組歸并方法和數組迭代方法共10類來進行詳細介紹對象繼承方法數組是一種特殊的對象,繼承了對象Object的toString()、toLocaleString()和valueOf()方法【toString()】toString()方法返回由數組中每個值的字符串形式拼接而成的一個以逗號分隔的字符串[注意]該方法的返回值與不使用任何參數調用join()方法返回的字符串相同[1,2,3].toString();//'1,2,3' ['a','b','c'].toString();//'a,b,c' [1,[2,'c']].toString();//'1,2,c'由于alert()要接收字符串參數,它會在后臺調用toString()方法,會得到與toString()方法相同的結果alert([1,2,3]);//'1,2,3' 【toLocaleString()】toLocaleString()是toString()方法的本地化版本,它經常也會返回與toString()方法相同的值,但也不總是如此。因為,它調用元素的是toLocaleString()方法將每個數組元素轉化為字符串var person1 = {toLocaleString: function(){return 'Nikolaos';},toString: function(){return 'Nicholas';} }; var person2 = {toLocaleString: function(){return 'Grigorios';},toString: function(){return 'Greg';} }; var people = [person1,person2]; console.log(people.toString());//'Nicholas,Greg' console.log(people.toLocaleString());//'Nikolaos,Grigorios'如果數組中的某一項的值是null或者undefined,則該值在toLocaleString()和toString()方法返回的結果中以空字符串表示var colors = [1,undefined,2,null,3]; console.log(colors.toString());//'1,,2,,3' console.log(colors.toLocaleString());//'1,,2,,3' 【valueOf()】valueOf()方法返回數組對象本身var a = [1, 2, 3]; console.log(a.valueOf());// [1, 2, 3] console.log(a.valueOf() instanceof Array);//true數組轉換方法 【join()】Array.join()方法是String.split()方法的逆向操作,后者是將字符串分割成若干塊來創建一個數組數組繼承的toLocaleString()和toString()方法,在默認情況下都會以逗號分隔的字符形式返回數組項;而join()方法可以使用不同的分隔符來構建這個字符串,join()方法只接收一個參數,用作分隔符的字符串,然后返回包含所有數組項的字符串如果不給join()方法傳入任何值,則使用逗號作為分隔符var a = [1,2,3]; console.log(a.join());//'1,2,3' console.log(a.join(' '));//'1 2 3' console.log(a.join(''));//'123'var b = new Array(10); b.join('-');//'---------',9個連字符組成的字符串若join()方法的參數是undefined,標準瀏覽器以逗號為分隔符返回字符串,而IE7-瀏覽器以'undefined'為分隔符返回字符串//標準瀏覽器為'1,2,3';IE7-瀏覽器為'1undefined2undefined3' var a = [1,2,3]; console.log(a.join(undefined));如果數組中的某一項的值是null或者undefined,則該值在join()方法返回的結果中以空字符串表示var colors = [1,undefined,2,null,3]; console.log(colors.join());//'1,,2,,3'該方法也可以用于類數組對象上console.log(Array.prototype.join.call('hello', '-'));// "h-e-l-l-o" var obj = { 0: 'a', 1: 'b', length: 2 }; console.log(Array.prototype.join.call(obj, '-'));// 'a-b'[注意]若對象沒有length屬性,就不是類數組,也就不能調用數組的方法var obj = { 0: 'a', 1: 'b' }; console.log(typeof Array.prototype.join.call(obj, '-'));//''棧和隊列方法push()和pop()方法允許將數組當作棧來使用。unshift()和shift()方法的行為非常類似于push()和pop(),不一樣的是前者是在數組的頭部而非尾部進行元素的插入和刪除操作棧是一種LIFO(Last-First-Out,后進先出)的數據結構,也就是最新添加的項最早被移除。而棧中項的插入(叫做推入)和移除(叫做彈出),只發生在一個位置——棧的頂部。javascript為數組專門提供了push()和pop()方法,以便實現類似棧的行為隊列數據結構的訪問規則是FIFO(first-in-first-out,先進先出)。隊列在列表的末端添加項,從列表的前端移除項。結合使用shift()和push()方法,可以像使用隊列一樣使用數組【push()】push()方法可以接收任意數量的參數,把它們逐個添加到數組末尾,并返回修改后數組的長度。所以,該數組會改變原數組var a = []; console.log(a,a.push(1));//[1] 1 console.log(a,a.push('a'));//[1,'a'] 2 console.log(a,a.push(true, {}));//[1,'a',true,{}] 4 console.log(a,a.push([5,6]));//[1,'a',true,{},[5,6]] 5如果需要合并兩個數組,可以使用apply方法var a = [1, 2, 3]; var b = [4, 5, 6]; console.log(a,Array.prototype.push.apply(a, b));//[1,2,3,4,5,6] 6[注意]如果使用call方法,則會把數組b整體看成一個參數var a = [1, 2, 3]; var b = [4, 5, 6]; console.log(a,Array.prototype.push.call(a, b));//[1,2,3,[4,5,6]] 4push()方法也可以向對象中添加元素,添加后的對象變成類數組對象,即新加入元素的鍵對應數組的索引,并且對象有一個length屬性var obj = {a: 1}; console.log(obj,[].push.call(obj, 2));// {a:1, 0:2, length: 1} console.log(obj,[].push.call(obj, [3]));// {a:1, 0:2, 1:[3], length: 2} 【pop()】pop()方法從數組末尾移除最后一項,減少數組的length值,然后返回移除的項。所以,該數組會改變原數組var a = ['a', 'b', 'c']; console.log(a,a.pop()); // ['a', 'b'] 'c'對空數組使用pop()方法,不會報錯,而是返回undefinedvar a = []; console.log(a,a.pop()); // [] undefined 【shift()】shift()方法移除數組中的第一個項并返回該項,同時數組的長度減1。所以,該數組會改變原數組var a = ['a', 'b', 'c']; console.log(a,a.shift());//['b', 'c'] 'a'對空數組使用shift()方法,不會報錯,而是返回undefinedvar a = []; console.log(a,a.shift());// [] undefined 【unshift()】unshift()方法在數組前端添加任意個項并返回新數組長度。所以,該數組會改變原數組var a = ['a', 'b', 'c']; console.log(a,a.unshift('x')); //['x', 'a', 'b', 'c'] 4當使用多個參數調用unshift()時,參數是一次性插入的而非一次一個地插入。這意味著最終的數組中插入的元素的順序和它們在參數列表中的順序一致var a = ['a', 'b', 'c']; console.log(a,a.unshift('x','y','z')); //['x','y','z','a', 'b', 'c'] 6[注意]在IE7-瀏覽器中,unshift()方法返回的總是undefined//標準瀏覽器下,返回[1] 1;而IE7-瀏覽器下,返回[1] undefined var a = []; console.log(a,a.unshift(1));數組排序方法數組中存在兩個可以直接用來重排序的方法: reverse()和sort() 【reverse()】reverse()方法用于反轉數組的順序,返回經過排序之后的數組;而原數組順序也發生改變var array = [1,2,4,3,5]; console.log(array,array.reverse());//[5,3,4,2,1] [5,3,4,2,1] var array = ['str',true,3]; console.log(array,array.reverse());//[3,true,'str'] [3,true,'str'] 【sort()】默認情況下,sort()方法按字符串升序排列數組項,sort方法會調用每個數組項的toString()方法,然后比較得到的字符串排序,返回經過排序之后的數組,而原數組順序也發生改變var array = [1,2,4,3,5]; console.log(array,array.sort());//[1,2,3,4,5] [1,2,3,4,5] var array = ['3str',3,2,'2']; console.log(array,array.sort());//[2, "2", 3, "3str"] [2, "2", 3, "3str"] var array = [1,5,10,50]; console.log(array,array.sort());//[1, 10, 5, 50] [1, 10, 5, 50]如果數組包含undefined元素,它們會被排到數組的尾部var array = ['3',3,undefined,2,'2']; console.log(array,array.sort());//["2", 2, "3", 3, undefined] ["2", 2, "3", 3, undefined]sort()方法可以接受一個比較函數作為參數,以便指定哪個值在哪個值的前面。比較函數接收兩個參數,如果第一個參數應該位于第二個參數之前則返回一個負數,如果兩個參數相等則返回0,如果第一個參數應該位于第二個參數之后則返回一個正數function compare(value1,value2){if(value1 < value2){return -1;}else if(value1 > value2){return 1;}else{return 0;} } var array = ['5px',50,1,10]; //當數字與字符串比較大小時,字符串'5px'會被轉換成NaN,這樣結果就是false console.log(array.sort(compare));//["5px",1, 10, 50]對于數值類型或valueOf()方法會返回數值類型的對象類型,比較函數可以簡化function compare(value1,value2){return value1 - value2; } var array = ['5px',50,1,10]; console.log(array.sort(compare));//["5px",1,10,50] var array = [5,50,1,10]; console.log(array.sort(compare));//[1,5,10,50]如果對一個字符串數組執行不區分大小寫的字母表排序,比較函數首先將參數轉化為小寫字符串再開始比較a = ['ant','Bug','cat','Dog']; a.sort();//['Bug','Dog','ant','cat']; a.sort(function(s,t){var a = s.toLowerCase();var b = t.toLowerCase();if(a < b)return -1;if(a > b)return 1;return 0; });//['ant','bug','cat','dog']【tips】使用sort()方法創建一個隨機數組function compare(){return Math.random() - 0.5; } var array = [1,2,3,4,5]; console.log(array.sort(compare));//[2,1,5,4,3]數組拼接方法 【concat()】concat()方法基于當前數組中的所有項創建一個新數組,先創建當前數組一個副本,然后將接收到的參數添加到這個副本的末尾,最后返回新構建的數組。所以concat()不影響原數組如果不給concat()方法傳遞參數時,它只是復制當前的數組;如果參數是一個或多個數組,則該方法會將這些數組中的每一項都添加到結果數組中;如果傳遞的值不是數組,這些值就會被簡單地添加到結果數組的末尾var numbers = [1,2]; console.log(numbers,numbers.concat(3,4));//[1,2] [1,2,3,4] console.log(numbers,numbers.concat([5,4,3],[3,4,5],1,2));//[1,2] [1,2,5,4,3,3,4,5,1,2] console.log(numbers,numbers.concat(4,[5,[6,7]]));//[1,2] [1,2,4,5,[6,7]]如果不提供參數,concat()方法返回當前數組的一個淺拷貝。所謂“淺拷貝”,指的是如果數組成員包括復合類型的值(比如對象),則新數組拷貝的是該值的引用//該方法實際只復制了數組的第一維,數組第一維存放的是第二維的引用,而第二維才是實際存放他們的內容 var numbers = [1,2]; var newNumbers = numbers.concat(); console.log(numbers,newNumbers);//[1,2] [1,2] numbers[0] = 0; console.log(numbers,newNumbers);//[0,2] [1,2]var numbers = [[1,2]]; var newNumbers = numbers.concat(); console.log(numbers,newNumbers);//[[1,2]] [[1,2]] numbers[0][0] = 0; console.log(numbers,newNumbers);//[[0,2]] [[0,2]]concat()方法也可以用于將對象合并為數組,但是必須借助call()方法var newArray = Array.prototype.concat.call({ a: 1 }, { b: 2 }) console.log(newArray);// [{ a: 1 }, { b: 2 }] console.log(newArray[0].a);//1創建子數組方法【slice()】slice()方法基于當前數組中的一個或多個項創建一個新數組,接受一個或兩個參數,即要返回項的起始和結束位置,最后返回新數組,所以slice()不影響原數組slice(start,end)方法需要兩個參數start和end,返回這個數組中從start位置到(但不包含)end位置的一個子數組;如果end為undefined或不存在,則返回從start位置到數組結尾的所有項如果start是負數,則start = max(length + start,0)如果end是負數,則end = max(length + end,0)start和end無法交換位置如果沒有參數,則返回原數組var numbers = [1,2,3,4,5]; console.log(numbers.slice(2));//[3,4,5] console.log(numbers.slice(2,undefined));//[3,4,5] console.log(numbers.slice(2,3));//[3] console.log(numbers.slice(2,1));//[]console.log(numbers.slice(-3));//-3+5=2 -> [3,4,5] console.log(numbers.slice(-8));//max(5 + -8,0)=0 -> [1,2,3,4,5]console.log(numbers.slice(0,-3));//-3+5=2 -> [1,2] console.log(numbers.slice(-2,-1));//-2+5=3;-1+5=4; -> [4]如果不提供參數,slice()方法返回當前數組的一個淺拷貝//該方法實際只復制了數組的第一維,數組第一維存放的是第二維的引用,而第二維才是實際存放他們的內容 var numbers = [1,2]; var newNumbers = numbers.slice(); console.log(numbers,newNumbers);//[1,2] [1,2] numbers[0] = 0; console.log(numbers,newNumbers);//[0,2] [1,2]var numbers = [[1,2]]; var newNumbers = numbers.slice(); console.log(numbers,newNumbers);//[[1,2]] [[1,2]] numbers[0][0] = 0; console.log(numbers,newNumbers);//[[0,2]] [[0,2]]slice()方法涉及到Number()轉型函數的隱式類型轉換,當start被轉換為NaN時,相當于start = 0;當end被轉換為NaN時(end為undefined除外),則輸出空數組var numbers = [1,2,3,4,5]; console.log(numbers.slice(NaN));//[1,2,3,4,5] console.log(numbers.slice(0,NaN));//[] console.log(numbers.slice(true,[3]));//[2,3] console.log(numbers.slice(null,undefined));//[1,2,3,4,5] console.log(numbers.slice({}));//[1,2,3,4,5] console.log(numbers.slice('2',[5]));//[3,4,5]可以使用slice()方法將類數組對象變成真正的數組var arr = Array.prototype.slice.call(arrayLike);Array.prototype.slice.call({ 0: 'a', 1: 'b', length: 2 })// ['a', 'b'] Array.prototype.slice.call(document.querySelectorAll("div")); Array.prototype.slice.call(arguments);數組刪改方法 【splice()】splice()和slice()擁有非常相似的名字,但它們的功能卻有本質的區別。splice()方法用于刪除原數組的一部分成員,并可以在被刪除的位置添加入新的數組成員,該方法會改變原數組splice()返回一個由刪除元素組成的數組,或者如果沒有刪除元素就返回一個空數組splice()的第一個參數start指定了插入或刪除的起始位置。如果start是負數,則start = max(length + start,0);如果start是NaN,則相當于start = 0如果只提供一個元素,相當于將原數組在指定位置拆分成兩個數組var a = [1,2,3,4,5,6,7,8]; console.log(a,a.splice());// [1,2,3,4,5,6,7,8] [] var a = [1,2,3,4,5,6,7,8]; console.log(a,a.splice(4));// [1,2,3,4] [5,6,7,8] var a = [1,2,3,4,5,6,7,8]; console.log(a,a.splice(-4));//-4+8=4; [1,2,3,4] [5,6,7,8] var a = [1,2,3,4,5,6,7,8]; console.log(a,a.splice(-9));//max(-9+8,0)=0 [] [1,2,3,4,5,6,7,8] var a = [1,2,3,4,5,6,7,8]; console.log(a,a.splice(NaN));//[] [1,2,3,4,5,6,7,8]第二個參數number指定了應該從數組中刪除的元素的個數。如果省略第二個參數,從起始點開始到數組結尾的所有元素都將被刪除。如果number是負數或NaN或undefined,則number=0,因此不刪除元素var a = [1,2,3,4,5,6,7,8]; console.log(a,a.splice(0,2));// [3,4,5,6,7,8] [1,2] var a = [1,2,3,4,5,6,7,8]; console.log(a,a.splice(10,2));// [1,2,3,4,5,6,7,8] [] var a = [1,2,3,4,5,6,7,8]; console.log(a,a.splice(1,100));// [1] [2,3,4,5,6,7,8] var a = [1,2,3,4,5,6,7,8]; console.log(a,a.splice(1,-5));//[1,2,3,4,5,6,7,8] [] var a = [1,2,3,4,5,6,7,8]; console.log(a,a.splice(1,NaN));//[1,2,3,4,5,6,7,8] [] var a = [1,2,3,4,5,6,7,8]; console.log(a,a.splice(1,undefined));//[1,2,3,4,5,6,7,8] []如果后面還有更多的參數,則表示這些就是要被插入數組的新元素var a = [1,2,3,4,5]; console.log(a,a.splice(2,0,'a','b'));//[1,2,'a','b',3,4,5] [] console.log(a,a.splice(2,2,[1,2],3));//[1,2,[1,2],3,3,4,5] ['a','b']數組位置方法ES5為數組實例添加了兩個位置方法:indexOf()、lastIndexOf()【indexOf()】indexOf(search,start)方法接收search和start兩個參數,返回search首次出現的位置,如果沒有找到則返回-1search參數表示要搜索的項;使用嚴格相等運算符(===)進行比較var arr = [1,2,3,'1','2','3']; console.log(arr.indexOf('2'));//4 console.log(arr.indexOf(3));//2 console.log(arr.indexOf(0));//-1start參數表示該搜索的開始位置,該方法會隱式調用Number()轉型函數,將start非數字值(undefined除外)轉換為數字。若忽略該參數或該參數為undefined或NaN時,start = 0var arr = ['a','b','c','d','e','a','b']; console.log(arr.indexOf('a',undefined));//0 console.log(arr.indexOf('a',NaN));//0 console.log(arr.indexOf('a',1));//5 console.log(arr.indexOf('a',true));//5 console.log(arr.indexOf('a',-1));//max(0,-1+7)=6; -1 console.log(arr.indexOf('a',-5));//max(0,-5+7)=2; 5 console.log(arr.indexOf('a',-50));//max(0,-50+7)=0; 0var person = {name: 'Nicholas'}; var people = [{name: 'Nicholas'}]; var morePeople = [person]; alert(people.indexOf(person));//-1,因為person和people[0]雖然值相同,但是是兩個引用 alert(morePeople.indexOf(person));//0,因為person和morepeople[0]是同一個引用 alert(morePeople.indexOf({name: 'Nicholas'}));//-1,因為不是同一個引用indexOf()方法兼容寫法if (typeof Array.prototype.indexOf != "function") {Array.prototype.indexOf = function (searchElement, fromIndex) {var index = -1;fromIndex = fromIndex * 1 || 0;for (var k = 0, length = this.length; k < length; k++) {if (k >= fromIndex && this[k] === searchElement) {index = k;break;}}return index;}; }【lastIndexOf()】與indexOf()不同,lastIndexOf()從右向左查找lastIndexOf(search,start)方法接收search和start兩個參數,返回search第一次出現的位置,如果沒有找到則返回-1search參數表示要搜索的項;使用嚴格相等運算符(===)進行比較var arr = [1,2,3,'1','2','3']; console.log(arr.lastIndexOf('2'));//4 console.log(arr.lastIndexOf(3));//2 console.log(arr.lastIndexOf(0));//-1start表示該搜索的開始位置,該方法會隱式調用Number()轉型函數,將start非數字值(undefined除外)轉換為數。若忽略該參數或該參數為undefined或NaN時,start = 0與字符串的lastIndexOf()方法不同,當search方法為負數時,search = max(0,length+search)var arr = ['a','b','c','d','e','a','b']; console.log(arr.lastIndexOf('b'));//6 console.log(arr.lastIndexOf('b',undefined));//-1 console.log(arr.lastIndexOf('a',undefined));//0 console.log(arr.lastIndexOf('b',NaN));//-1 console.log(arr.lastIndexOf('b',1));//1 console.log(arr.lastIndexOf('b',-1));//max(0,-1+7)=6; 6 console.log(arr.lastIndexOf('b',-5));//max(0,-5+7)=2; 1 console.log(arr.lastIndexOf('b',-50));//max(0,-50+7)=0; -1【tips】返回滿足條件的項的所有索引值可以通過循環調用indexOf()或lastIndexOf()來找到所有匹配的項function allIndexOf(array,value){var result = [];var pos = array.indexOf(value);if(pos === -1){return -1;}while(pos > -1){result.push(pos);pos = array.indexOf(value,pos+1);}return result; } var array = [1,2,3,3,2,1]; console.log(allIndexOf(array,1));//[0,5] lastIndexOf()方法兼容寫法 if (typeof Array.prototype.lastIndexOf != "function") {Array.prototype.lastIndexOf = function (searchElement, fromIndex) {var index = -1, length = this.length;fromIndex = fromIndex * 1 || length - 1;for (var k = length - 1; k > -1; k-=1) {if (k <= fromIndex && this[k] === searchElement) {index = k;break;}}return index;}; }數組歸并方法數組歸并方法包括reduce()和reduceRight()方法兩種,它們使用指定的函數將數組元素進行組合,生成單個值。這在函數式編程中是常見的操作,也可以稱為“注入”和“折疊”【reduce()】reduce()方法需要兩個參數。第一個是執行化簡操作的函數。化簡函數的任務就是用某種方法把兩個值組合或化簡為一個值,并返回化簡后的值化簡函數接受四個參數,分別是:【1】初始變量,默認為數組的第一個元素值。函數第一次執行后的返回值作為函數第二次執行的初始變量,依次類推【2】當前變量,如果指定了第二個參數,則該變量為數組的第一個元素的值,否則,為第二個元素的值【3】當前變量對應的元素在數組中的索引(從0開始)【4】原數組對象化簡函數的這四個參數之中,只有前兩個是必須的,后兩個則是可選的values.reduce(function(prev, cur, index, array){//todo });reduce()方法第二個(可選)的參數是一個傳遞給函數的初始值var a = [1,2,3,4,5]; var sum = a.reduce(function(x,y){return x+y},0);//數組求和 var product = a.reduce(function(x,y){return x*y},1);//數組求積 var max = a.reduce(function(x,y){return (x>y)?x:y;});//求最大值[1, 2, 3, 4, 5].reduce(function(prev, cur){console.log(prev, cur)return prev+ cur; }); // 1 2 // 3 3 // 6 4 // 10 5 //最后結果:15[1, 2, 3, 4, 5].reduce(function(prev, cur){console.log(prev, cur);return prev + cur; },0); // 0 1 // 1 2 // 3 3 // 6 4 // 10 5 //最后結果:15[注意]reduce()方法的返回結果類型和傳入的初始值相同[1, 2, 3, 4, 5].reduce(function(prev, cur){console.log(prev.sum, cur);prev.sum = prev.sum + cur;return prev; },{sum:0}); //0 1 //1 2 //3 3 //6 4 //10 5 //Object {sum: 15}利用reduce()方法,可以寫一個數組求和的sum方法Array.prototype.sum = function (){return this.reduce(function (prev, cur){return prev + cur;}) }; [3,4,5,6,10].sum();// 28由于reduce方法依次處理每個元素,所以實際上還可以用它來搜索某個元素。比如,找出長度最長的數組元素function findLongest(entries) {return entries.reduce(function (prev, cur) {return cur.length > prev.length ? cur : prev;}, ''); } console.log(findLongest([1,2,3,'ab',4,'bcd',5,6785,4]));//'bcd'可以利用reduce()方法,實現二維數組的扁平化var matrix = [[1, 2],[3, 4],[5, 6] ]; // 二維數組扁平化 var flatten = matrix.reduce(function (prev, cur) {return prev.concat(cur); }); console.log(flatten); // [1, 2, 3, 4, 5, 6]在空數組上,不帶初始值參數調用reduce()將導致類型錯誤異常。如果調用它的時候只有一個值——數組只有一個元素并且沒有指定初始值,或者有一個空數組并且指定一個初始值——reduce()只是簡單地返回那個值而不會調用化簡函數var arr = []; arr.reduce(function(){});//Uncaught TypeError: Reduce of empty array with no initial valuevar arr = []; arr.reduce(function(){},1);//1reduce()方法兼容寫法if (typeof Array.prototype.reduce != "function") {Array.prototype.reduce = function (callback, initialValue ) {var previous = initialValue, k = 0, length = this.length;if (typeof initialValue === "undefined") {previous = this[0];k = 1;}if (typeof callback === "function") {for (k; k < length; k++) {this.hasOwnProperty(k) && (previous = callback(previous, this[k], k, this));}}return previous;}; }【reduceRight()】reduceRight()的工作原理和reduce()一樣,不同的是它按照數組索引從高到低(從右到左)處理數組,而不是從低到高var values = [1,2,3,4,5]; var sum = values.reduceRight(function(prev, cur, index, array){console.log(prev,cur);return prev + cur; }); console.log(sum); //5 4 //9 3 //12 2 //14 1 //15reduceRight()方法兼容寫法if (typeof Array.prototype.reduceRight != "function") {Array.prototype.reduceRight = function (callback, initialValue ) {var length = this.length, k = length - 1, previous = initialValue;if (typeof initialValue === "undefined") {previous = this[length - 1];k--;}if (typeof callback === "function") {for (k; k > -1; k-=1) { this.hasOwnProperty(k) && (previous = callback(previous, this[k], k, this));}}return previous;}; }數組迭代方法ECMAScript5為數組定義了5個迭代方法。每個方法都接收兩個參數:要在每一項上運行的函數和(可選的)運行該函數的作用域對象——影響this的值。傳入這些方法中的函數會接收三個參數:數組項的值、該項在數組中的位置和數組對象本身。根據使用的方法不同,這個函數執行后的返回值可能會也可能不會影響訪問的返回值function(item,index,array){//todo } 【map()】map()方法對數組的每一項運行給定函數,返回每次函數調用的結果組成的數組//f是array的每一個元素調用的函數。它的返回值成為返回數組的元素;o是f調用時的可選this值 array.map(f,o); [1,2,3].map(function(item,index,arr){return item*item});//[1,4,9] [1,2,3].map(function(item,index,arr){return item*index});//[0,2,6]map()方法還可以接受第二個參數,表示回調函數執行時this所指向的對象var arr = ['a','b','c']; [1,2].map(function(item,index,arr){return this[item]},arr);//['b','c']在實際使用的時候,可以利用map()方法方便獲得對象數組中的特定屬性值var users = [{name:'t1',email:'t1@qq.com'},{name:'t2',email:'t2@qq.com'},{name:'t3',email:'t3@qq.com'}]; console.log(users.map(function(item,index,arr){return item.email}));//["t1@qq.com", "t2@qq.com", "t3@qq.com"]map()方法還可以用于類數組對象Array.prototype.map.call('abc',function(item,index,arr){return item.toUpperCase()});//["A", "B", "C"]對于稀疏數組,map()方法不會在實際上不存在元素的序號上調用函數var a = [1,,3]; console.log(a.map(function(item,index,arr){return item*2;}));//[2, 2: 6]map()方法兼容寫法if (typeof Array.prototype.map != "function") {Array.prototype.map = function (fn, context) {var arr = [];if (typeof fn === "function") {for (var k = 0, length = this.length; k < length; k++) { arr.push(fn.call(context, this[k], k, this));}}return arr;}; }【forEach()】forEach()方法對數組中的每一項運行給定函數,這個方法沒有返回值。本質上與for循環迭代數組一樣。如果需要有返回值,一般使用map方法[1,2,3,4].forEach(function(item,index,arr){console.log(item) }); //1 //2 //3 //4類似于如下的for循環var array = [1, 2, 3, 4]; for (var k = 0, length = array.length; k < length; k++) {console.log(array[k]); }使用forEach()方法實現簡單的加法var sum = 0; [1, 2, 3, 4].forEach(function (item, index, array) {sum += item; }); console.log(sum);//10forEach()方法除了接受一個必須的回調函數參數,第二個參數還可以接受一個可選的上下文參數(改變回調函數里面的this指向)var out = []; [1, 2, 3].forEach(function(elem){this.push(elem * elem); }, out); console.log(out);// [1, 4, 9]第二個參數對于多層this非常有用,因為多層this通常指向是不一致的,可以使用forEach()方法的第二個參數固定thisvar obj = {name: '張三',times: [1, 2, 3],print: function () {//該this指向objconsole.log(this);this.times.forEach(function (n) {//該this指向windowconsole.log(this);});} }; obj.print();var obj = {name: '張三',times: [1, 2, 3],print: function () {//該this指向objconsole.log(this);this.times.forEach(function (n) {//該this同樣指向objconsole.log(this);},this);} }; obj.print();forEach()循環可以用于類數組對象var str = 'abc'; Array.prototype.forEach.call(str, function(item, index, array) {console.log( item + ':' + index); }); //a:0 //b:1 //c:2與for循環不同,對于稀疏數組,forEach()方法不會在實際上不存在元素的序號上調用函數var a = [1,2,3]; delete a[1]; for(var i = 0; i < a.length; i++){console.log(a[i]); } //1 //undefined //3a.forEach(function(item,index,arr){console.log(item)}); //1 //3forEach()方法無法在所有元素都傳遞給調用的函數之前終止遍歷。也就是說,沒有像for循環中使用的相應的break語句。如果要提前終止,必須把forEach()方法放在一個try塊中,并能拋出一個異常for(var i = 0; i < 5; i++){if(i == 2) break; } console.log(i);//2 var a = [1,2,3,4,5]; console.log(a.forEach(function(item,index,arr){if(index == 2) break;//Uncaught SyntaxError: Illegal break statement }));var a = [1,2,3,4,5]; a.forEach(function(item,index,arr){try{if(item == 2) throw new Error; }catch(e){console.log(item);} });forEach()方法兼容寫法if(typeof Array.prototype.forEach != 'function'){Array.prototype.forEach = function(fn,context){for(var k = 0,length = this.length; k < length; k++){if(typeof fn === 'function' && Object.prototype.hasOwnProperty.call(this,k)){fn.call(context,this[k],k,this);}}} }【filter()】filter()方法對數組中的每一項運行給定函數,返回該函數會返回true的項組成的數組。該方法常用于查詢符合條件的所有數組項[1, 2, 3, 4, 5].filter(function (elem) {return (elem > 3); });// [4, 5] [0, 1, 'a', false].filter(Boolean);// [1, "a"][1, 2, 3, 4, 5].filter(function (elem, index, arr) {return index % 2 === 0; });// [1, 3, 5]filter()方法還可以接受第二個參數,指定測試函數所在的上下文對象(this對象)var Obj = function () {this.MAX = 3; }; var myFilter = function (item) {if (item > this.MAX) {return true;} }; var arr = [2, 8, 3, 4, 1, 3, 2, 9]; arr.filter(myFilter, new Obj());// [8, 4, 9]filter()會跳過稀疏數組中缺少的元素,它的返回數組總是稠密的,所以可以壓縮稀疏數組的空缺var a = [1,2,,,,3,,,,4]; console.log(a.length);//10 var dense = a.filter(function(){return true;}) console.log(dense,dense.length);//[1,2,3,4] 4如果要壓縮空缺并刪除undefined和null元素,可以這樣使用filter()方法var a = [1,2,,undefined,,3,,null,,4]; console.log(a.length);//10 var dense = a.filter(function(item){return item!= undefined;}) console.log(dense,dense.length);//[1,2,3,4] 4filter()方法兼容寫法if (typeof Array.prototype.filter != "function") {Array.prototype.filter = function (fn, context) {var arr = [];if (typeof fn === "function") {for (var k = 0, length = this.length; k < length; k++) {fn.call(context, this[k], k, this) && arr.push(this[k]);}}return arr;}; }【some()】some()方法對數組中的每一項運行給定函數,如果該函數對任一項返回true,則返回true。并且當且僅當數值中的所有元素調用判定函數都返回false,它才返回falsea = [1,2,3,4,5]; a.some(function(elem, index, arr){return elem%2===0;})//true a.some(isNaN);//false在空數組上調用some()方法會返回false[].some(function(){});//falsesome()方法兼容寫法if (typeof Array.prototype.some != "function") {Array.prototype.some = function (fn, context) {var passed = false;if (typeof fn === "function") {for (var k = 0, length = this.length; k < length; k++) {if (passed === true) break;passed = !!fn.call(context, this[k], k, this);}}return passed;}; }【every()】every()方法對數組中的每一項運行給定函數,如果該函數對每一項都返回true,則返回true;只要有一項返回false,則返回falsea = [1,2,3,4,5]; a.every(function(elem, index, arr){elem < 10;})//true a.every(function(elem, index, arr){return elem%2 ===0;});//false在空數組上調用every()方法會返回true[].every(function(){});//trueevery()方法兼容寫法if (typeof Array.prototype.every != "function") {Array.prototype.every = function (fn, context) {var passed = true;if (typeof fn === "function") {for (var k = 0, length = this.length; k < length; k++) {if (passed === false) break;passed = !!fn.call(context, this[k], k, this);}}return passed;}; }總結javascript數組方法特意定義為通用的,因此它們不僅應用在真正的數組而且在類數組對象上都能正確工作。這22種方法中,除了toString()和toLocaleString()以外的所有方法都是通用的可以改變原數組的方法總共有7種:包括unshift()、shift()、push()、pop()這4種棧和隊列方法,reverse()和sort()這2種數組排列方法,數組刪改方法splice()

轉載于:https://www.cnblogs.com/xuyuanjia/p/5743560.html

總結

以上是生活随笔為你收集整理的javascript中数组的22种方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

wwwwwww黄 | 色国产在线| 久久精品国产免费看久久精品 | 日韩在线观看免费 | 精品国产色 | 激情视频亚洲 | 超碰免费观看 | 国产97在线看 | 狠狠色狠狠色综合系列 | 四虎国产免费 | 亚洲成年人免费网站 | 日韩av看片 | 久久精品视频国产 | 亚洲色综合 | 欧美日韩性视频在线 | 狠狠操.com | 久草久草在线观看 | 男女激情片在线观看 | 中文在线中文a | 免费视频黄 | www.午夜| 深爱激情av | 91在线观看高清 | 91在线看视频免费 | 久久精品第一页 | 色综合久久悠悠 | 国产精品毛片一区二区三区 | 精品久久精品久久 | 国产黄色精品在线 | 五月婷社区 | 精品国产一区二区三区男人吃奶 | 亚洲国产免费网站 | 国产一区二区精品在线 | 五月激情天 | 国产区精品区 | 中文在线a∨在线 | 天天弄天天干 | 中文字幕在线观看不卡 | 亚洲精品视频在线免费播放 | 天天色婷婷 | 成人综合婷婷国产精品久久免费 | 在线观看黄a | 亚洲激情视频在线观看 | 久久久久久高潮国产精品视 | 免费高清国产 | 精品1区2区3区 | 久影院| 日韩综合色 | 成人黄色电影在线 | 久久久久 | 亚洲天堂视频在线 | 国产精品成人一区二区 | 黄色小网站在线观看 | 国内三级在线 | 日韩在线中文字幕 | 精品国产诱惑 | 久久综合九色综合欧美就去吻 | 久久久久久美女 | 亚洲在线a | 国产黑丝一区二区 | 久久综合电影 | 色吧av色av | 国产亚洲精品美女 | 日韩在线国产 | 视频在线观看99 | 久久蜜臀一区二区三区av | 日b黄色片 | 欧美人交a欧美精品 | 日韩国产精品一区 | 久草剧场 | 久草在线最新视频 | 91在线视频免费 | 亚洲最大av网 | 天堂av一区二区 | 日韩欧美一级二级 | 色综合久久综合中文综合网 | 亚洲人成免费 | 福利一区在线 | 婷婷丁香激情 | 日韩手机在线 | www.干| 亚洲v精品 | 久久99亚洲精品久久 | 欧美一二三区播放 | 亚洲视频免费在线 | 少妇自拍av | 激情av一区二区 | 成年人免费在线观看 | 91伊人| 最新久久免费视频 | 日本狠狠干 | 天堂入口网站 | 91在线视频播放 | 国产一区福利在线 | 国产性xxxx | 中文字幕免费高 | 精品国内自产拍在线观看视频 | 久久国产精品视频 | 亚洲黄色成人 | 久久久久久久亚洲精品 | 国产成人亚洲在线电影 | 在线黄色av | 五月婷婷在线观看视频 | 亚洲欧美婷婷六月色综合 | 午夜婷婷在线观看 | 在线日本看片免费人成视久网 | 91视频久久久久 | 91视频在线看 | 成人久久精品 | 成人av网站在线 | 亚洲电影av在线 | 免费在线观看成年人视频 | 久久久久欠精品国产毛片国产毛生 | aaa亚洲精品一二三区 | 97超碰香蕉 | www.黄色在线| 成人黄色小说视频 | 丁香花在线观看免费完整版视频 | 亚洲国产精品资源 | 人人草在线视频 | 国产在线更新 | 在线观看亚洲成人 | 久久久精品亚洲 | 天天综合天天做天天综合 | 中文十次啦 | 缴情综合网五月天 | 婷婷久操 | 九九热免费在线视频 | 天堂av免费看 | 中国美女一级看片 | 欧美性生活免费 | 久久久91精品国产一区二区精品 | 超碰人人做 | 国产午夜精品一区二区三区在线观看 | 97在线免费视频 | 在线视频电影 | 色天天 | 国产亚洲精品美女久久 | 丁香六月天 | 国产韩国精品一区二区三区 | 久久久国产精品一区二区三区 | 欧美一级特黄aaaaaa大片在线观看 | 欧美一区日韩一区 | 天天干天天爽 | 在线观看你懂的网站 | 久久五月婷婷丁香社区 | 日韩亚洲在线 | 欧洲一区精品 | 二区视频在线 | 国产小视频在线观看 | 成人app在线播放 | 在线观看免费黄色 | 97国产精品 | 国产精品免费麻豆入口 | 麻豆成人在线观看 | 天天天色综合 | 国产精品久久久久9999 | 91精品入口 | 99国产视频在线 | 成人久久精品视频 | 一区二区三区在线不卡 | 久久精品2| 日韩免费一二三区 | 免费在线黄 | 在线a视频免费观看 | 欧美日韩精品综合 | 日韩激情三级 | 成人网在线免费视频 | 一级电影免费在线观看 | 日韩在线看片 | 日本公妇色中文字幕 | 久久久免费| 日韩免费观看av | 成人av网站在线 | 最近日本中文字幕 | 国产香蕉在线 | 亚洲午夜大片 | 啪啪免费试看 | 久久一二三四 | 久久国产精品影视 | 91av综合| 国产精品美女久久久久久久久 | 免费福利视频导航 | 婷婷久久综合九色综合 | 欧美日韩二三区 | 中文字幕日韩av | 97超碰人人澡人人爱学生 | 夜夜看av | 国产精品成久久久久三级 | 亚洲闷骚少妇在线观看网站 | 天天鲁天天干天天射 | 香蕉视频免费看 | 久久草网站 | 亚州精品天堂中文字幕 | 日韩r级电影在线观看 | 色婷婷视频在线 | 国产91精品久久久久久 | 亚洲一级影院 | 人人澡av | 中文字幕在线看视频国产 | 欧美日韩不卡一区二区 | 蜜臀久久99静品久久久久久 | 免费在线观看一区二区三区 | 99国内精品久久久久久久 | 射久久久| 女人魂免费观看 | 中文字幕在线播放视频 | 91精品国自产在线观看 | 日韩草比| 国产成人av综合色 | 亚洲国产精品一区二区久久hs | 超碰在线天天 | 成人一级片视频 | 国产成人一区二区三区久久精品 | 亚洲精品色视频 | 国产香蕉视频在线播放 | av免费网站观看 | 一区二区三区高清在线观看 | 久久激情五月婷婷 | 最近av在线| 日批在线观看 | 精品在线播放 | 韩日精品在线 | 国产在线看 | 久久精品99精品国产香蕉 | 91九色蝌蚪视频 | 视频一区二区精品 | 日韩 在线a | 国内99视频 | 久久久久久久久国产 | 国产99久久久国产精品免费看 | 又污又黄的网站 | 免费在线国产 | 国产黄色在线网站 | 91av官网 | 久久公开免费视频 | 国产不卡精品 | 欧美激情精品久久久久久变态 | 色爽网站 | 亚洲视屏一区 | 韩国av一区 | 超碰97在线看| 久草视频在线免费看 | 国产色在线视频 | 正在播放国产精品 | 人人狠 | 18网站在线观看 | 精品国产一区二区三区久久久 | 天天操夜夜操天天射 | 国产成人中文字幕 | 91尤物在线播放 | 91视频在线免费观看 | 婷婷在线网站 | 啪啪激情网| 夜夜视频欧洲 | 91激情视频在线观看 | www.狠狠色 | 国产精品欧美久久久久三级 | 色久av | 中文字幕大全 | 欧美激情奇米色 | 日韩在线免费播放 | 日本特黄一级 | 911久久香蕉国产线看观看 | 一级α片| 欧美精品国产综合久久 | 色成人亚洲网 | 日韩精品免费一线在线观看 | 亚洲日本va午夜在线电影 | 美女黄色网在线播放 | 中文字幕欧美日韩va免费视频 | 亚洲免费成人av电影 | 国产在线一线 | 伊人射| 久久神马影院 | 成人a级黄色片 | 欧美精品一区二区蜜臀亚洲 | 亚洲精品影视在线观看 | 丁香五香天综合情 | 91成人网在线 | 久久精品一区二区三区四区 | 日韩精品在线看 | 国产黄视频在线观看 | 国产精品情侣视频 | 91中文字幕永久在线 | 最近中文字幕视频网 | 在线视频日韩欧美 | 六月丁香婷 | 四虎在线视频免费观看 | 国产99一区视频免费 | 在线国产视频一区 | 狠狠操综合 | 国产成人精品一区二区 | 久久久美女| 久久精品国产一区二区三 | 日韩精品欧美视频 | 国产区免费 | 国产欧美精品一区二区三区 | 91在线porny国产在线看 | 久久久久久美女 | 亚洲dvd| 91麻豆精品国产午夜天堂 | 日韩视频专区 | 欧美精品免费在线 | 精品在线观看一区二区 | 免费在线看成人av | 伊人婷婷激情 | 久久精品一区二区三区国产主播 | 五月香婷| 日本激情视频中文字幕 | 精品美女在线视频 | 麻豆国产精品视频 | 免费视频久久久 | 波多野结衣电影久久 | 久草在线看片 | av资源网在线播放 | 97理论电影 | 国产黄大片在线观看 | 久久国产精品一区二区 | 久久 地址 | 天天综合久久 | 亚洲专区欧美专区 | 亚洲精品久久激情国产片 | 久久九九久久精品 | 欧美日韩xxx | 欧洲高潮三级做爰 | 国产精品久久久久久久久久久久冷 | 三级av免费观看 | 欧美国产不卡 | 欧美a级片免费看 | 亚洲开心色 | 91精品国产自产老师啪 | 久草资源免费 | 久久影视精品 | 欧美激情综合五月色丁香 | 中文字幕在线观看免费观看 | www.黄色小说.com| 日韩欧三级 | 国产一级电影网 | 干天天| 婷婷丁香花五月天 | 精品一区三区 | 五月天综合网站 | 激情综合一区 | 九九精品视频在线观看 | 精品久久久久久综合日本 | 中文字幕第 | 奇米四色影狠狠爱7777 | 亚洲综合婷婷 | 欧美日韩国产欧美 | 日韩欧美91 | 国产成人精品综合久久久久99 | 一区二区高清在线 | 久香蕉| 日韩免费视频一区二区 | 久久久久色| 婷婷婷国产在线视频 | 97精品国产97久久久久久春色 | 日韩精品大片 | 天天操夜夜操国产精品 | 国产手机视频 | 美女福利视频一区二区 | 精品在线二区 | 国产免费嫩草影院 | 天天干天天色2020 | 久久久国产在线视频 | 三级黄色片子 | 99精品欧美一区二区三区黑人哦 | 一区二区三区四区影院 | 成人综合日日夜夜 | 一区二区三区电影大全 | 久久久男人的天堂 | 91看片在线播放 | 亚洲视频在线看 | 色视频在线观看 | 91人人干 | 久久久 激情 | 91成人在线观看喷潮 | 亚洲视频一 | 日韩精品亚洲专区在线观看 | 人人插人人澡 | 久久精品久久久久久久 | 久久少妇| 国产精品尤物视频 | 久久精品综合网 | 亚洲成aⅴ人片久久青草影院 | 日韩精品欧美视频 | 国产一级小视频 | 成人黄色小视频 | 亚洲免费国产 | www亚洲一区 | 精品96久久久久久中文字幕无 | 国产精品视频一二三 | 99视频在线观看一区三区 | 999国内精品永久免费视频 | 99视频这里只有 | 在线免费观看的av网站 | 亚洲色综合 | 久久久国产在线视频 | 黄色一级片视频 | 91九色九色| 久久久久 | 欧美日韩精品在线 | 国产精品永久久久久久久久久 | 亚洲精品观看 | 久久久久久久久久久久电影 | 久久五月情影视 | 在线一二三区 | 亚洲少妇xxxx| 亚洲国产中文字幕 | 日日夜夜av | 日韩性网站 | 六月激情丁香 | 欧美另类一二三四区 | 亚洲成人精品av | 五月婷婷伊人网 | 中文字幕在线不卡国产视频 | 免费看一及片 | 色婷婷狠狠五月综合天色拍 | 天天摸天天舔天天操 | 天天操天天操一操 | 久久精品国产精品亚洲 | 99久热在线精品 | 久久er99热精品一区二区 | 国产999精品久久久久久 | 毛片永久新网址首页 | 欧美一区二区日韩一区二区 | 8x成人免费视频 | 中文字幕丝袜美腿 | 久久久精品国产免费观看一区二区 | 国产精品久久久久久久久久东京 | 日韩毛片在线免费观看 | 婷婷5月色 | 日韩一区二区三区视频在线 | 91av官网 | 欧美日韩在线精品 | 久久精品久久精品久久 | 欧美性性网 | 婷婷激情综合网 | 日韩久久精品一区二区三区下载 | 国产色久 | 色亚洲网| 偷拍精偷拍精品欧洲亚洲网站 | 日韩一区二区免费在线观看 | av九九| 日韩一区二区三区在线观看 | 国产日本在线播放 | av超碰在线观看 | 久久久国产在线视频 | 国产视频一区二区在线观看 | 综合网天天色 | 亚洲精品综合一区二区 | 免费热情视频 | 亚洲黄色一级大片 | 日韩在线视频免费播放 | 国产精品精品久久久久久 | 亚洲国产精品成人女人久久 | 片黄色毛片黄色毛片 | 四虎影视久久久 | 在线免费三级 | 国产精品18久久久久久不卡孕妇 | 国产精品一区二区三区观看 | 亚洲综合精品在线 | 国产一级精品在线观看 | 久久久久久国产精品999 | 欧美巨大荫蒂茸毛毛人妖 | 91精品国产福利在线观看 | 国产精品一区二区吃奶在线观看 | 日本中文在线观看 | 日日操天天操夜夜操 | 人人超在线公开视频 | 夜夜躁狠狠躁日日躁视频黑人 | 激情文学综合丁香 | 97综合网| 91九色国产蝌蚪 | 欧美日本不卡 | 黄色网www| 成年人电影毛片 | 久久综合射 | 色婷婷五| 精品国偷自产在线 | 久久免费高清视频 | 在线观看视频你懂得 | 日韩三级免费 | 国产69精品久久久久久 | 丁香六月婷婷 | 久久久久久麻豆 | 在线免费观看黄色 | 日韩精品高清不卡 | 欧美精品v国产精品v日韩精品 | 午夜视频黄 | 免费看一级特黄a大片 | 免费成人av网站 | 五月婷婷久 | 香蕉久久久久久av成人 | 国产91免费在线 | 五月婷婷激情综合网 | 亚洲一区二区三区毛片 | 精品国产一区二区三区在线观看 | 日韩精品免费在线观看视频 | 不卡视频一区二区三区 | 日本中文字幕网 | 精品国产一区二区三区在线观看 | 91精品一| 久久久国产高清 | 99r国产精品| 亚洲国产中文在线 | 久草网免费 | 日韩a级黄色片 | 麻豆你懂的 | 天天射成人| 97超碰色 | 人人添人人澡 | 日本中文字幕免费观看 | 国产精品美女视频网站 | 欧美性天天 | av福利在线导航 | 免费看黄色大全 | 91精品综合在线观看 | 99se视频在线观看 | 成人国产电影在线观看 | 中文字幕免费观看视频 | 欧美成人h版电影 | 日韩高清av| 一级黄色在线免费观看 | 国产三级视频在线 | 三级视频日韩 | 2019精品手机国产品在线 | 免费手机黄色网址 | 国产探花在线看 | 精品一区二区三区香蕉蜜桃 | www.久久久久 | 亚洲乱亚洲乱亚洲 | 久精品视频免费观看2 | 狠狠色丁香婷婷综合橹88 | 奇米网777| 超碰国产在线观看 | 激情视频区 | 久久成人免费电影 | 亚洲一级电影视频 | 99re8这里有精品热视频免费 | 精品在线免费观看 | 青青啪| 狠狠狠狠狠狠 | 国产二区免费视频 | 美女久久久久久久久久 | 国产91av视频在线观看 | 久久午夜精品视频 | 国产精品嫩草55av | 亚洲乱码国产乱码精品天美传媒 | 免费网站黄 | 激情综合啪 | 中文字幕日韩有码 | 九九久久影院 | 天天射天天干天天操 | 一级免费观看 | av在线网站大全 | 欧美日韩免费观看一区=区三区 | 国产高清久久久久 | 一区二区视频电影在线观看 | 亚洲精品在线观看视频 | 国产成人免费网站 | 日韩有码在线观看视频 | 五月婷婷操 | 激情视频亚洲 | 一区二区三区中文字幕在线观看 | 中文字幕日本在线观看 | 日本性视频 | 亚洲japanese制服美女 | 欧美日韩免费观看一区=区三区 | 中文字幕视频观看 | 成年人国产在线观看 | 日日干美女 | 国产伦精品一区二区三区照片91 | 久久区二区 | 亚洲欧美日韩精品一区二区 | 久精品视频免费观看2 | 日韩一级电影网站 | 奇米影视四色8888 | 久久久久免费精品视频 | 欧美精品国产综合久久 | 日韩欧美精品在线观看 | 91超级碰碰| 免费网站色 | 亚洲中字幕 | 人人爽人人澡人人添人人人人 | 在线观看免费视频你懂的 | 黄网站app在线观看免费视频 | 99精品在线免费在线观看 | 欧美亚洲专区 | 欧美韩日视频 | 999国产在线 | 成人理论在线观看 | 国产精品2020 | 国产精品理论视频 | 粉嫩一二三区 | 超碰人人国产 | 国产亚洲久一区二区 | 婷婷色婷婷 | 精品免费视频123区 午夜久久成人 | 在线观看91精品视频 | 日本中文乱码卡一卡二新区 | 99久久久久久久久久 | 久久久国产电影 | 色婷婷狠 | 女人18毛片90分钟 | 日韩在线网址 | 日韩欧美视频一区二区三区 | www黄色com| 99久久久久久久久久 | 9久久精品 | 亚洲国产婷婷 | 国产精品一区二区三区久久久 | 成人毛片久久 | 特级片免费看 | 国产精品一区二区在线 | 久久久久成人精品 | 视频国产在线观看18 | 夜夜看av| 国内综合精品午夜久久资源 | 久久久久久蜜av免费网站 | 深爱五月网| 91手机视频 | 成人午夜电影免费在线观看 | 亚洲国产999 | 久久久久免费看 | 午夜色性片 | 久久激情片 | 国产99久久久精品视频 | 中文字幕在线观看视频网站 | 91精品国产91 | 国产69久久久 | 天天爱天天 | 免费成人在线观看 | 国产日韩精品在线 | 激情网站免费观看 | 91福利视频免费 | 高清av中文在线字幕观看1 | 国产尤物一区二区三区 | 久久99精品国产麻豆宅宅 | 婷婷av电影 | 最近中文字幕高清字幕免费mv | 麻豆一区二区 | 免费视频一级片 | 亚洲国产操 | 国产精品一区二区久久久久 | 亚洲在线免费视频 | 国产九九九精品视频 | 黄免费网站 | 免费观看黄 | 午夜精品久久久久久中宇69 | 最近2019年日本中文免费字幕 | 黄色网大全| 国产精品美女久久久网av | 黄色三级在线看 | 国产96在线视频 | 天天色天天艹 | 日韩高清一二三区 | 精品一区二区三区在线播放 | 国产精品18久久久久vr手机版特色 | 日韩电影中文字幕在线观看 | 亚洲精品视频久久 | 久久99国产视频 | 国产美女永久免费 | 在线观看国产成人av片 | 久草a在线| 亚洲第一区在线观看 | 亚洲精品成人在线 | 97操操操| 国产69精品久久久久99尤 | 深爱婷婷网 | 日韩视频区 | 天天操天天色天天射 | 欧美极度另类性三渗透 | 最近中文字幕高清字幕免费mv | 99视屏 | 亚洲精品乱码久久久久久蜜桃欧美 | 欧美一级电影免费观看 | 四虎天堂 | 久久成人毛片 | 欧洲精品视频一区二区 | 久久99深爱久久99精品 | 中国黄色一级大片 | 国产一线二线三线性视频 | 国产成人精品久久二区二区 | 国产麻豆成人传媒免费观看 | 久久免费视频观看 | 亚洲日本中文字幕在线观看 | 久久ww| 日韩高清免费电影 | 91av蜜桃 | 欧美日韩视频在线观看一区二区 | 亚洲日本中文字幕在线观看 | 手机版av在线 | 丁香婷婷深情五月亚洲 | av日韩不卡| 亚洲激情国产精品 | 欧美成人猛片 | 西西www444| 亚洲日本欧美在线 | 久久激情婷婷 | 久久久久国产免费免费 | 国产亚洲成av人片在线观看桃 | 成人毛片100免费观看 | 国产色婷婷在线 | 午夜av一区| 久久久精品网 | 久久精品黄 | 夜色资源站国产www在线视频 | 91在线免费观看国产 | 中文字幕一区三区 | 婷婷精品在线 | 91最新在线 | 日韩欧美在线免费观看 | 国产日产在线观看 | 欧美成人91 | 国产精品视频99 | 精品久久久久国产 | 色综合在 | 欧美不卡视频在线 | 久久精久久精 | 精品久久国产一区 | 亚洲欧美精品一区 | 国产中文在线观看 | 五月天伊人 | 手机看片1042 | 五月天网站在线 | 91精品啪在线观看国产线免费 | 国产精品久久久久久久久蜜臀 | 日韩国产精品久久久久久亚洲 | 国产99久久| 日韩中文字幕免费视频 | 99视频精品免费观看, | 国产午夜精品久久久久久久久久 | 久久久久综合精品福利啪啪 | 狠狠色狠狠色合久久伊人 | 成人免费毛片aaaaaa片 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 久久久久久久久久久网 | 欧美成人tv| 日本中文字幕在线观看 | 国产精品午夜在线观看 | 欧美日韩中文字幕综合视频 | 中文永久字幕 | 五月婷在线播放 | 亚洲毛片久久 | 国产视频一区二区三区在线 | 伊人伊成久久人综合网站 | 欧美一级大片在线观看 | 国产在线播放一区二区 | 午夜精品久久久久久久久久久久久久 | 免费合欢视频成人app | 久草在线视频国产 | 免费精品视频在线 | av在线不卡观看 | 成人精品视频久久久久 | 日本在线视频一区二区三区 | 亚洲视频免费在线看 | 欧美精品一区在线 | 麻豆影视在线观看 | 国产精品一区二区三区99 | 久久综合九色九九 | 五月综合在线观看 | 成人毛片100免费观看 | 在线国产视频 | 国产精品女人久久久久久 | 日韩中文字幕免费电影 | 中国一级特黄毛片大片久久 | 99精品视频一区二区 | 免费观看福利视频 | 青青河边草免费视频 | 美女福利视频网 | 国产免码va在线观看免费 | 国产一级二级av | 超级碰碰免费视频 | 色欧美日韩 | 成人免费看电影 | 日韩一二三在线 | 日韩激情一二三区 | 超级碰碰免费视频 | 超碰av免费 | 国产精品免费久久久久久 | 97色噜噜| 欧美日韩国产色综合一二三四 | 91精品久久久久久综合五月天 | 亚洲综合色丁香婷婷六月图片 | 国产精品毛片一区二区在线 | 国产第一页精品 | 国产丝袜制服在线 | 日韩午夜三级 | 日日干狠狠操 | 国产精品18毛片一区二区 | 日韩欧美在线综合网 | 日韩在线观看影院 | 国产午夜精品一区二区三区欧美 | 久久综合狠狠综合久久激情 | 美女在线免费观看视频 | 中文字幕av最新 | 在线播放 亚洲 | 国产精品毛片一区二区三区 | 免费看一及片 | 中文字幕国产在线 | 在线91视频 | 福利视频一二区 | 成人羞羞视频在线观看免费 | 日产乱码一二三区别在线 | 久香蕉| 国产免费中文字幕 | 日韩欧美一区二区不卡 | 天天综合婷婷 | 精品国产乱码久久久久久1区二区 | 日韩三级视频在线观看 | 国产日韩欧美视频在线观看 | 九九热在线精品 | 国产精品久久久久婷婷 | 最新国产一区二区三区 | 五月天久久狠狠 | 国产高清视频在线播放 | 一本一本久久a久久精品牛牛影视 | 99国产精品久久久久老师 | 激情综合色播五月 | 最新日韩视频 | 在线视频手机国产 | 国产精品嫩草影院123 | 日本精品一区二区三区在线播放视频 | 五月婷婷香蕉 | 国产精品自拍在线 | 免费精品在线观看 | 国产一区二区高清 | 永久免费毛片在线观看 | 亚洲香蕉视频 | 国产精品午夜久久久久久99热 | 国产精品一区二区三区视频免费 | 日本丶国产丶欧美色综合 | 粉嫩av一区二区三区四区 | 欧美精品亚洲精品日韩精品 | 日韩va亚洲va欧美va久久 | 九九九九色 | 久久精品国产一区二区电影 | 亚洲一级电影视频 | 91九色丨porny丨丰满6 | 欧美做受高潮电影o | 成人va天堂 | 亚洲理论在线观看电影 | 成人福利在线播放 | 精品久久久久久电影 | 毛片基地黄久久久久久天堂 | 99热播精品 | 亚洲传媒在线 | 亚洲综合成人婷婷小说 | 午夜丰满寂寞少妇精品 | 在线免费观看黄色av | 特片网久久 | 91自拍视频在线观看 | 欧美日韩精品在线播放 | 国产剧在线观看片 | 久久久 激情 | 毛片网在线播放 | 国产 一区二区三区 在线 | 亚洲国产欧美在线人成大黄瓜 | 正在播放 国产精品 | 麻花天美星空视频 | 91成人免费电影 | 国产精品福利在线播放 | 午夜精品一区二区三区四区 | 成人午夜黄色 | 中文字幕在线观看免费 | 国产成人在线一区 | 国产一区视频导航 | 久久人人爽人人人人片 | 91亚洲狠狠婷婷综合久久久 | 欧美日韩久久一区 | 欧美成人视 | 在线色资源 | 成人少妇影院yyyy | 免费h在线观看 | 亚洲丝袜一区 | 欧美日产在线观看 | 色综合天天综合 | 国产精品高清免费在线观看 | 国产美女主播精品一区二区三区 | 午夜12点 | 色噜噜在线观看 | 日韩视频在线观看视频 | 国产精品久久久久久久久久直播 | 国产小视频你懂的在线 | 国产精品第72页 | 在线观看岛国片 | 免费av网址在线观看 | 不卡电影免费在线播放一区 | 国产美女视频网站 | 国产成人精品一区二区三区网站观看 | 中文字幕在线影视资源 | 国产女教师精品久久av | 亚洲情感电影大片 | 99久久精品网 | 激情视频免费在线 | 日韩三级视频在线观看 | 成人欧美一区二区三区黑人麻豆 | 欧美精品中文字幕亚洲专区 | www.色婷婷.com | av在线免费在线观看 | 国产精品久久网 | 日韩有码中文字幕在线 | 性色av免费在线观看 | a√国产免费a| 中文字幕在线观看一区二区三区 | 97碰碰碰| 在线观看网站你懂的 | 在线有码中文字幕 | 成人一区二区三区在线观看 | 高清不卡一区二区三区 | 欧美调教网站 | 精品国产福利在线 | 996久久国产精品线观看 | 亚洲精品在线观 | 国产精品麻豆一区二区三区 | 麻豆91视频 | 国产资源中文字幕 | 99九九视频| 久草在线视频首页 | 夜色在线资源 | 日韩手机在线 | 色老板在线 | 一区二区三区在线视频111 | 天天天天射 | 久久开心激情 | 国产中文字幕在线播放 | 青青草国产精品视频 | 中文电影网 | 婷婷久月 | 九九热在线精品视频 | 国产精品一区二区美女视频免费看 | 成人av直播 | 亚洲精品乱码久久久一二三 | 天天干亚洲 | 亚洲精品中文在线资源 | 在线视频一二区 | av综合在线观看 | 免费av看片 | 日韩精品一区二区三区水蜜桃 | 国产精品美女久久久久久2018 | 日韩xxxbbb| 中文字幕在线看视频 | 日韩精品久久久久久久电影99爱 | 国产精品一区二区久久国产 | 91免费在线视频 | 欧美日韩一区二区免费在线观看 | 九九热精品国产 | 伊人视频 | 久久久久久久久亚洲精品 | 91色视频| 亚洲一级黄色片 | 亚洲精品午夜国产va久久成人 | 九九久久久久久久久激情 | 99久久激情视频 | 久久综合久久鬼 | 中文字幕在线色 | 国产午夜精品一区二区三区嫩草 | 中文字幕在线视频网站 | 在线观看黄色大片 | 国产大片黄色 | 中文字幕91 | 国产精品久久久久久a | 国产免费黄视频在线观看 | 国产高清亚洲 | 欧美成人精品欧美一级乱黄 | 一级α片免费看 | a在线免费 | 97色在线观看 | 麻豆一二三精选视频 | 天天舔天天搞 | 久久天天躁 | 国产免费区 | 射九九| 日韩成人在线免费观看 | 丁香六月激情婷婷 | 日韩免费观看视频 | 国产成人精品av久久 | 婷婷激情影院 | 成人性生交大片免费看中文网站 | 中文字幕一区在线 | 久久av观看 | 中文字幕在线看视频 | 99在线观看 | 99精品影视| 91大片网站 | 欧美激情综合色综合啪啪五月 | 欧美成人xxxx | 五月婷亚洲 | 成人在线视频论坛 | 中文av在线免费观看 | 人人超碰在线 | 人人干人人超 | 亚洲精品资源在线观看 | 韩日av一区二区 | 国产精品视频区 | 四虎永久免费在线观看 |