<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                合規國際互聯網加速 OSASE為企業客戶提供高速穩定SD-WAN國際加速解決方案。 廣告
                ## 在Javascript中什么是偽數組?如何將偽數組轉化為標準數組? 偽數組(類數組): 無法直接調用數組方法或期望length屬性有什么特殊的行為,不具有數組的push,pop等方法,但仍可以對真正數組遍歷方法來遍歷它們。典型的是函數的argument參數,還有像調用getElementsByTagName,document.childNodes之類的,它們都返回NodeList對象都屬于偽數組。可以使用Array.prototype.slice.call(fakeArray)將數組轉化為真正的Array對象。 function log(){ var args = Array.prototype.slice.call(arguments); //為了使用unshift數組方法,將argument轉化為真正的數組 args.unshift('(app)'); console.log.apply(console, args); }; 這里把符合以下條件的對象稱為偽數組: 1,具有length屬性 2,按索引方式存儲數據 3,不具有數組的push,pop等方法 如 1,function內的arguments 。 2,通過document.forms,Form.elements,Select.options,document.getElementsByName() , document.getElementsByTagName() ,childNodes/children 等方式獲取的集合(HTMLCollection,NodeList)等。 3,特殊寫法的對象 ,如 Js代碼 收藏代碼 var obj={}; obj[0] = "一"; obj[1] = "二"; obj[2] = "三"; obj.length = 3; 它們不具有數組的一些方法如push, pop, shift, join等。有時候需要將這些偽數組轉成真正的數組,這樣可以使用push, pop等方法。以下是工具函數makeArray Js代碼 function makeArray(obj){ var rs=[],len=obj.length; try{ rs = [].slice.call(obj,0); }catch(e){ //for IE for(var i=0;j=obj[i++];){ rs.push(j); } } return rs; } 以下分別測試以上三種偽數組: Js代碼 //定義一個函數fun,內部使用makeArray將其arguments轉換成數組 //定義一個函數fun,內部使用makeArray將其arguments轉換成數組 function fun(){ var ary = makeArray(arguments); alert(ary.constructor ); } //調用 fun(3,5); //假設頁面上有多個段落元素p var els = document.getElementsByTagName("p"); var ary1 = makeArray(els); alert(ary1.constructor); //特殊的js對象(如jquery對象) var obj={}; obj[0] = "一"; obj[1] = "二"; obj[2] = "三"; obj.length = 3; var ary2 = makeArray(obj); alert(ary2.constructor); >[warning] 引自[https://www.cnblogs.com/fly-xfa/p/5908012.html](https://www.cnblogs.com/fly-xfa/p/5908012.html) >若侵犯了您的權益,請聯系me
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看