javascript - js的shift()方法失效?
問(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方法。
相關(guān)文章:
1. objective-c - iOS開發(fā)支付寶和微信支付完成為什么跳轉(zhuǎn)到了之前開發(fā)的一個(gè)app?2. mysql優(yōu)化 - 關(guān)于mysql分區(qū)3. 請(qǐng)教各位大佬,瀏覽器點(diǎn) 提交實(shí)例為什么沒(méi)有反應(yīng)4. 致命錯(cuò)誤: Class ’appfacadeTest’ not found5. javascript - ionic2 input autofocus 電腦成功,iOS手機(jī)鍵盤不彈出6. python - 管道符和ssh傳文件7. css - 移動(dòng)端字體設(shè)置問(wèn)題8. css - 求推薦適用于vue2的框架 像bootstrap這種類型的9. html5 - 如何實(shí)現(xiàn)帶陰影的不規(guī)則容器?10. javascript - 循環(huán)嵌套多個(gè)promise應(yīng)該如何實(shí)現(xiàn)?
