javascript - es6擴展運算符...的問題
問題描述
擴展符復制數組我能理解,但用于函數傳遞參數的不懂
如上,為什么函數參數加上擴展運算符以后,就能接受若干個參數?
fn(...arg)要怎么理解
問題解答
回答1:函數定義的時候, 這應該叫剩余參數.
如果函數的最后一個命名參數以...為前綴,則在函數被調用時,該形參會成為一個數組,數組中的元素都是傳遞給該函數的多出來的實參的值。
看 MDN 詳細解釋:https://developer.mozilla.org...
回答2:你可以先看一下這個栗子
這里的...arg其實是獲取arguments的值,所以你方法可以改寫成這樣
function fn(){ var arg = [...arguments]; console.log(...arg);}回答3:
把arguments轉換成數組
回答4:官方解釋:
Bind trailing parameters to an array.
用在函數參數中,就是將此處開始的參數轉換成一個數組。
fn(...args)//所有參數變為數組fn(a, ...args)//從第二個參數變為數組回答5:
函數的形參本來就會保存到argument這個類數組里邊,...操作符可以把類數組轉成數組
回答6:你需要ECMAScript 6 入門
回答7:你可以理解為,fn(...arg) 是將參數的參數,全部放置在arg這個數組里.不管你調這函數時,傳多少個參數,都可以由arg來獲取.
函數參數可以通過arguments這個類數組對象獲得,你傳入的任意多參數本質上在函數內部就是以類數組對象存在的,所以加上擴展運算符,只是把這個類數組變成了參數序列
相關文章:
1. docker images顯示的鏡像過多,狗眼被亮瞎了,怎么辦?2. javascript - Web微信聊天輸入框解決方案3. 請教各位大佬,瀏覽器點 提交實例為什么沒有反應4. javascript - avalon使用:duplex設置select默認option的bug5. Matlab和Python編程相似嗎,有兩種都學過的人可以說說嗎6. docker - 如何修改運行中容器的配置7. css - 對于類選擇器使用的問題8. javascript - 音頻加載問題9. 網頁爬蟲 - 用Python3的requests庫模擬登陸Bilibili總是提示驗證碼錯誤怎么辦?10. javascript - 移動端textarea不能上下滑動,該怎么解決?
