91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ES6函數怎么用

發布時間:2022-02-19 10:00:53 來源:億速云 閱讀:116 作者:小新 欄目:開發技術

這篇文章給大家分享的是有關ES6函數怎么用的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

ECMAScript 6.0(以下簡稱ES6)是JavaScript語言的下一代標準,已經在2015年6月正式發布了。它的目標,是使得JavaScript語言可以用來編寫復雜的大型應用程序,成為企業級開發語言。

ES6函數怎么用

函數參數的擴展

默認參數

基本用法

function fn(name,age=17){
console.log(name+","+age);
}
fn("Amy",18);  // Amy,18
fn("Amy","");  // Amy,
fn("Amy");     // Amy,17

注意點:使用函數默認參數時,不允許有同名參數。

// 不報錯function fn(name,name){
console.log(name);
}

// 報錯
//SyntaxError: Duplicate parameter name not allowed in this contextfunction fn(name,name,age=17){
console.log(name+","+age);
}

只有在未傳遞參數,或者參數為 undefined 時,才會使用默認參數,null 值被認為是有效的值傳遞。

function fn(name,age=17){
   console.log(name+","+age);
}
fn("Amy",null); // Amy,null

函數參數默認值存在暫時性死區,在函數參數默認值表達式中,還未初始化賦值的參數值無法作為其他參數的默認值。

function f(x,y=x){
   console.log(x,y);
}
f(1);  // 1 1function f(x=y){
   console.log(x);
}
f();  // ReferenceError: y is not defined
不定參數

不定參數用來表示不確定參數個數,形如,…變量名,由…加上一個具名參數標識符組成。具名參數只能放在參數組的最后,并且有且只有一個不定參數。

基本用法

function f(...values){
   console.log(values.length);
}
f(1,2);      //2
f(1,2,3,4);  //4
箭頭函數

箭頭函數提供了一種更加簡潔的函數書寫方式。基本語法是:

參數 => 函數體 基本用法:

var f = v => v;
//等價于
var f = function(a){return a;
}
f(1);  //1

當箭頭函數沒有參數或者有多個參數,要用 () 括起來。

var f = (a,b) => a+b;
f(6,2);  //8

當箭頭函數函數體有多行語句,用 {} 包裹起來,表示代碼塊,當只有一行語句,并且需要返回結果時,可以省略 {} , 結果會自動返回。

var f = (a,b) => {let result = a+b;return result;
}
f(6,2);  // 8

當箭頭函數要返回對象的時候,為了區分于代碼塊,要用 () 將對象包裹起來

// 報錯
var f = (id,name) => {id: id, name: name};
f(6,2);  // SyntaxError: Unexpected token :

// 不報錯
var f = (id,name) => ({id: id, name: name});
f(6,2);  // {id: 6, name: 2}

注意點:沒有 this、super、arguments 和 new.target 綁定。

var func = () => {
 // 箭頭函數里面沒有 this 對象,
 // 此時的 this 是外層的 this 對象,即 Window
 console.log(this)
}
func(55)  // Window

var func = () => {    
 console.log(arguments)
}
func(55);  // ReferenceError: arguments is not defined

箭頭函數體中的 this 對象,是定義函數時的對象,而不是使用函數時的對象。

function fn(){
 setTimeout(()=>{
   // 定義時,this 綁定的是 fn 中的 this 對象
   console.log(this.a);
 },0)
}
var a = 20;
// fn 的 this 對象為 {a: 19}
fn.call({a: 18});  // 18

不可以作為構造函數,也就是不能使用 new 命令,否則會報錯

適合使用的場景

ES6 之前,JavaScript 的 this 對象一直很令人頭大,回調函數,經常看到 var self = this 這樣的代碼,為了將外部 this 傳遞到回調函數中,那么有了箭頭函數,就不需要這樣做了,直接使用 this 就行。

// 回調函數
var Person = {
   'age': 18,
   'sayHello': function () {
     setTimeout(function () {
       console.log(this.age);
     });
   }
};
var age = 20;
Person.sayHello();  // 20

var Person1 = {
   'age': 18,
   'sayHello': function () {
     setTimeout(()=>{
       console.log(this.age);
     });
   }
};
var age = 20;
Person1.sayHello();  // 18

所以,當我們需要維護一個 this 上下文的時候,就可以使用箭頭函數。

不適合使用的場景

定義函數的方法,且該方法中包含 this

var Person = {
   'age': 18,
   'sayHello': ()=>{
       console.log(this.age);
     }
};
var age = 20;
Person.sayHello();  // 20
// 此時 this 指向的是全局對象

var Person1 = {
   'age': 18,
   'sayHello': function () {
       console.log(this.age);
   }
};
var age = 20;
Person1.sayHello();   // 18
// 此時的 this 指向 Person1 對象

需要動態 this 的時候

var button = document.getElementById('userClick');
button.addEventListener('click', () => {
    this.classList.toggle('on');
});

button 的監聽函數是箭頭函數,所以監聽函數里面的 this 指向的是定義的時候外層的 this 對象,即 Window,導致無法操作到被點擊的按鈕對象。

感謝各位的閱讀!關于“ES6函數怎么用”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

es6
AI

大庆市| 土默特左旗| 雷波县| 修武县| 全南县| 黑山县| 黄龙县| 古交市| 昭觉县| 安龙县| 青州市| 锦州市| 天门市| 谢通门县| 荔波县| 北安市| 锡林浩特市| 长武县| 龙口市| 若尔盖县| 永嘉县| 正定县| 乌拉特后旗| 抚松县| 修武县| 富源县| 保康县| 兴和县| 苍山县| 伊吾县| 连云港市| 康乐县| 楚雄市| 绥宁县| 嘉黎县| 巩义市| 景宁| 浦北县| 泾川县| 深圳市| 唐海县|