第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機(jī)立即綁定

javascript 類數(shù)組轉(zhuǎn)數(shù)組的四種姿勢

標(biāo)簽:
JavaScript

科普 什么是类数组


  1. 拥有length属性,其它属性(索引)为非负整数(对象中的索引会被当做字符串来处理,这里你可以当做是个非负整数串来理解)

var aDivs = document.querySelectorAll('div'); // 类数组function hello (){  console.log(arguments);//类数组
  console.log(arguments.length);
}
hello(1);var arr = {'1':'哈哈','2':'呼呼','4':'嘿嘿',length:5};// 类数组var str=Array.prototype.join.call(a,'+');//'+哈哈+呼呼++嘿嘿'//非类数组示例var noArr = {'1':2};   //没有length属性就不是类数组
  • 2.不具有数组所具有的方法

shift,unshift,splice,slice,concat,reverse,sort...

为什么要转换类数组为数组

由于类数组不具有数组所具有的操作数组的方法,将类数组转换为数组之后就能调用如shift,unshift,splice,slice,concat,reverse,sort等这些强大的方法。

如何转换 类数组=>数组

html

<!DOCTYPE html><html><head>
    <meta charset="utf-8">
    <title>爱问医康</title></head><body>
    <img id="hitarea" class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="http://imgdev.cdn.chspu.com/2018/06/27/a40052fa.jpg" />
    <div ></div>
    <div ></div></body><script class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="test.js"></script></html>

第一种 Array.prototype.slice.call(arguments)

var aDivs = document.querySelectorAll('div');console.log("是否是數組 =>",aDivs instanceof Array);var newArr = Array.prototype.slice.call(aDivs);console.log(newArr);console.log("是否是數組 =>",newArr instanceof Array);

webp

image.png

第二种 Array.prototype.concat.apply([],aDivs)

var aDivs = document.querySelectorAll('div');console.log(aDivs);console.log("是否是數組 =>",aDivs instanceof Array);var newArr3 = Array.prototype.concat.apply([],aDivs);
newArr3.push(1);console.log(newArr3);console.log("是否是數組 =>",newArr3 instanceof Array);

webp

image.png

第三种 Array.prototype.splice.apply()

var aDivs = document.querySelectorAll('div');console.log(aDivs);console.log("是否是數組 =>",aDivs instanceof Array);var resultArr = [];var argumentsArr=[0,0];for (var i = 0; i < aDivs.length; i++) {
  argumentsArr.push(aDivs[i]);  
}Array.prototype.splice.apply(resultArr,argumentsArr);console.log(resultArr);console.log("是否是數組 =>",resultArr instanceof Array);

webp

image.png

第四种 新建一个数组,然后直接push进去(这样感觉是在作弊啊 【偷笑脸】)

var aDivs = document.querySelectorAll('div');console.log(aDivs);console.log("是否是數組 =>",aDivs instanceof Array);var resultArr = [];for (var i = 0; i < aDivs.length; i++) {
  resultArr.push(aDivs[i]);  
}console.log(resultArr);console.log("是否是數組 =>",resultArr instanceof Array);

webp

image.png

完结

总结
明显Array.prototype.slice.call(arguments),这种方式优势明显。



作者:小枫学幽默
链接:https://www.jianshu.com/p/2996e48f23e5


點擊查看更多內(nèi)容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優(yōu)質(zhì)文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學(xué)習(xí),寫下你的評論
感謝您的支持,我會繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊有機(jī)會得

100積分直接送

付費專欄免費學(xué)

大額優(yōu)惠券免費領(lǐng)

立即參與 放棄機(jī)會
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號

舉報

0/150
提交
取消