色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

javascript - js的shift()方法失效?

瀏覽:130日期:2023-03-25 18:00:19

問題描述

如題,代碼如下:

<ul class='demo'> <li>1</li> <li>2</li> <li>3</li> <li>4</li> <li>5</li> <li>6</li></ul><script> var l = document.getElementsByClassName('demo')[0]; var a = l.children; var r=a.shift(); console.log(r);//報(bào)錯(cuò):a.shift is not a function?</script>

類數(shù)組對象不能調(diào)用shift方法api?

問題解答

回答1:

類數(shù)組不是數(shù)組,沒有繼承數(shù)組的相關(guān)api,可以用call或者apply來綁定this,比如

var r = [].shift.call(a)

ps: shift還涉及到操作數(shù)組的內(nèi)容,剛試了一下,強(qiáng)行用call來shift類數(shù)組對象,會報(bào)相關(guān)對象不能修改length的限定,如果還涉及dom的處理,建議還是用相關(guān)dom操作,比如removeChild啥的,這個(gè)就不擴(kuò)展了。 dom類數(shù)組對象的相關(guān)資料可以在mdn找找,比如:https://developer.mozilla.org...

回答2:

shift會修改原數(shù)組,導(dǎo)致length屬性改變,但是length是只讀的。通過下面方式可以使用。

<ul class='demo'> <li>1</li> <li>2</li> <li>3</li> <li>4</li> <li>5</li> <li>6</li></ul></body><script> var l = document.getElementsByClassName('demo')[0]; var a = l.children; var arry = [...a]; var r=arry.shift(); console.log(r);</script>回答3:

當(dāng)然,shift是數(shù)組的方法,可以先把類數(shù)組轉(zhuǎn)成數(shù)組再調(diào)用Array.prototype.slice.call(arraylike);

回答4:

console.log(a)可以看到:__proto__:HTMLCollection HTMLCollection中并沒有shift方法。

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 亚洲va中文字幕欧美不卡 | 男女在线观看视频 | 精品一区二区三区亚洲 | 国产精品99精品久久免费 | 香港毛片免费观看 | 欧美成人免费sss | 三级黄色毛片视频 | 性欧美一级毛片 | 一级毛片一级毛片一级毛片 | 一级a级国产不卡毛片 | 暖暖免费高清日本一区二区三区 | 国产在线精品成人一区二区三区 | 日本在线视频播放 | 草草影院免费 | 99久久精品免费国产一区二区三区 | 一级黄一片 | 久草免费在线观看视频 | 丁香婷婷影音先锋5566 | 久久久毛片免费全部播放 | 亚洲成人自拍 | 国产成人a一区二区 | 久久精品国产免费中文 | 毛片视频网站在线观看 | 国产日韩免费 | 尹人香蕉久久99天天拍 | 亚洲欧美片 | 亚洲国产综合人成综合网站00 | 国产在线精品福利91香蕉 | 久久午夜影视 | 在线高清免费爱做网 | 成人韩免费网站 | 男人透女人超爽视频免费 | 久久国产国内精品对话对白 | 亚洲欧美在线精品一区二区 | 亚洲欧美7777 | 免费a级毛片视频 | 日韩毛片在线播放 | 中文字幕乱码中文乱码51精品 | 亚洲日韩中文字幕 | 91福利精品老师国产自产在线 | 精品国产自在在线在线观看 |