国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

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

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

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

問(wèn)題描述

如題,代碼如下:

<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ù)組對(duì)象不能調(diào)用shift方法api?

問(wèn)題解答

回答1:

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

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

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

回答2:

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

<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中并沒(méi)有shift方法。

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 宿迁市| 武汉市| 航空| 外汇| 灵武市| 巨鹿县| 嘉义县| 福州市| 黄石市| 北票市| 安丘市| 封丘县| 商河县| 泗洪县| 梓潼县| 崇仁县| 梨树县| 都匀市| 涡阳县| 屏东市| 榆社县| 辰溪县| 大洼县| 治县。| 张掖市| 长白| 鞍山市| 新宁县| 平远县| 金门县| 冷水江市| 绥滨县| 康保县| 周宁县| 济南市| 九龙坡区| 宣恩县| 新巴尔虎左旗| 大英县| 香河县| 黄浦区|