javascript - js的shift()方法失效?
問題描述
如題,代碼如下:
<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方法。
相關(guān)文章:
1. Docker for Mac 創(chuàng)建的dnsmasq容器連不上/不工作的問題2. javascript - 求賜教:網(wǎng)易郵箱Web端模擬登錄看信的加密參數(shù)_ntes_nnid、_ntes_nuid3. javascript - 使用angular 的ui-sref 中出現(xiàn)了中文參數(shù),點(diǎn)擊跳轉(zhuǎn)后瀏覽器的地址欄里出現(xiàn)轉(zhuǎn)義后的%AE....%a%44. java - ConcurrentHashMap中的get()方法為什么可以不加鎖?5. javascript - QWebEngineView 如何爬 angular 的動態(tài)數(shù)據(jù)?6. html5 - 這個(gè)代碼顯示功能如何實(shí)現(xiàn)?7. javascript - 用JS 七牛上傳圖片出現(xiàn)文件已存在的錯(cuò)誤(file exists)8. 工作近5年,3年Java Web ,近2年前端,未來何去何從?9. css3 - 圖片等比例縮放10. java - 字節(jié)流轉(zhuǎn)成字符串之后,在通過字符串轉(zhuǎn)成字節(jié)流后的文件為什么會不一樣?
