亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

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

汕尾市| 榆社县| 岳普湖县| 兴安县| 龙泉市| 淄博市| 清新县| 宝清县| 正宁县| 石阡县| 翁源县| 泗阳县| 道真| 绍兴市| 三穗县| 抚松县| 灌阳县| 海兴县| 泉州市| 石渠县| 连南| 双牌县| 水富县| 吐鲁番市| 来安县| 东平县| 潼南县| 平昌县| 工布江达县| 新郑市| 敖汉旗| 中卫市| 广丰县| 海阳市| 重庆市| 惠东县| 盘山县| 余干县| 塘沽区| 莱西市| 大城县|