久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:155日期: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);//報錯:a.shift is not a function?</script>

類數組對象不能調用shift方法api?

問題解答

回答1:

類數組不是數組,沒有繼承數組的相關api,可以用call或者apply來綁定this,比如

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

ps: shift還涉及到操作數組的內容,剛試了一下,強行用call來shift類數組對象,會報相關對象不能修改length的限定,如果還涉及dom的處理,建議還是用相關dom操作,比如removeChild啥的,這個就不擴展了。 dom類數組對象的相關資料可以在mdn找找,比如:https://developer.mozilla.org...

回答2:

shift會修改原數組,導致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:

當然,shift是數組的方法,可以先把類數組轉成數組再調用Array.prototype.slice.call(arraylike);

回答4:

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

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 黄山市| 梅州市| 松阳县| 长泰县| 土默特左旗| 五常市| 尚志市| 牙克石市| 五家渠市| 平江县| 澜沧| 婺源县| 廊坊市| 丹江口市| 拉孜县| 商丘市| 兴化市| 凤台县| 昭平县| 元谋县| 达拉特旗| 宣城市| 资溪县| 汝阳县| 永定县| 全椒县| 稷山县| 承德市| 叶城县| 乌兰县| 黄平县| 贵州省| 和政县| 西藏| 永仁县| 福州市| 琼中| 南丰县| 通渭县| 大庆市| 钟祥市|