成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

【JS基礎】作用域和閉包

SolomonXie / 2362人閱讀

摘要:變量提升的理解語言的執(zhí)行規(guī)則先定義,后執(zhí)行變量定義函數(shù)聲明就屬于定義代碼的范疇注意函數(shù)聲明和函數(shù)表達式的區(qū)別說明幾種不同的使用場景要在執(zhí)行時才能確認值,定義時無法確認全局環(huán)境下的對象方法中的構(gòu)造函數(shù)中的事件函數(shù)中的觸發(fā)當前事件的對象中的創(chuàng)建

變量提升的理解
js語言的執(zhí)行規(guī)則:先定義,后執(zhí)行
變量定義、函數(shù)聲明就屬于定義代碼的范疇(注意“函數(shù)聲明”和“函數(shù)表達式”的區(qū)別)
說明this幾種不同的使用場景

this 要在執(zhí)行時才能確認值,定義時無法確認

var a = {
    name: "A",
    fn: function () {
        console.log(this.name);
    }
};
a.fn(); // this === a
a.fn.call({name: "B"}); // this === {name: "B"}
var fn1 = a.fn;
fn1(); // this === window

全局環(huán)境下的this

function fn() {
    console.log(this); // this === window
}
fn();

對象方法中的this

var obj = {
    name: "A",
    printName: function () {
        console.log(this.name); // this === obj
    }
};
obj.printName();

構(gòu)造函數(shù)中的this

function Foo(name) {
    this.name = name; // this === f
}
var f = new Foo("can");

事件函數(shù)中的this

document.getElementById("div1").onclick = function () {
    console.log(this); // this === 
div1
觸發(fā)當前事件的Element對象 };

call apply bind 中的this

function fn1(name, age) {
    console.log(name, age);
    console.log(this); // this === {x:100}
}

fn1.call({x: 100}, "can", 22);
fn1.apply({x: 100}, ["can", 22]);

var fn2 = function (name, age) {
    console.log(name, age);
    console.log(this); // this === {y:200}
}.bind({y: 200});
fn2("can", 22);
創(chuàng)建10個a標簽,點擊的時候彈出來對應的序號
for (var i = 0; i < 10; i++) {
    (function (i) {
        // 函數(shù)作用域
        var a = document.createElement("a");
        a.innerHTML = i + "
"; a.addEventListener("click", function (e) { e.preventDefault(); alert(i); // i 是自由變量,去父作用域?qū)ふ? }); document.body.appendChild(a); })(i); }
作用域

ES5中,無塊級作用域

if (true) {
    var name = "can";
}
console.log(name); // "can"

函數(shù)和全局作用域

var b = 1;
function fn3() {
    var b = 2;
    console.log("fn", b); // 2
}
console.log("global", b); // 1
fn3();

自由變量

var a = 100;
function fn4() {
    var b = 200;
    // 當前作用域沒有定義的變量,即“自由變量”
    console.log(a); // 100  a 是自由變量,去父作用域?qū)ふ?    console.log(b); // 200
}
fn4();
一個函數(shù)的父級作用域,是它定義時的父級作用域,而不是執(zhí)行時

作用域鏈,即自由變量的查找

var a = 100;
function fn5() {
    var b = 200;
    function fn6() {
        var c = 300;
        console.log(a); // 100  a 是自由變量,去父作用域?qū)ふ?        console.log(b); // 200  b 是自由變量,去父作用域?qū)ふ?        console.log(c); // 300
    }
    fn6();
}
fn5();
閉包的使用場景

1.函數(shù)作為返回值

function fn1() {
    var a = 100;
    // 返回一個函數(shù)(函數(shù)作為返回值)
    return function () {
        console.log(a); // a是自由變量,去父作用域?qū)ふ?    }
}

// f1 得到一個函數(shù)
var f1 = fn1();
var a = 200;
f1(); // 100

2.函數(shù)作為參數(shù)傳遞

function fn1() {
    var a = 100;
    // 返回一個函數(shù)(函數(shù)作為返回值)
    return function () {
        console.log(a); // a是自由變量,去父作用域?qū)ふ?    }
}

// f1 得到一個函數(shù)
var f1 = fn1();

function fn2(fn) {
    var a = 200;
    fn();
}

fn2(f1); // 100
實際開發(fā)中閉包的應用

閉包實際應用中主要用于封裝變量,收斂權(quán)限

function isFirstLoad() {
    var list = [];
    return function (id) {
        if (list.indexOf(id) > -1) {
            return false;
        } else {
            list.push(id);
            return true;
        }
    }
}
// 在 isFirstLoad 函數(shù)外面,不可能修改到 list 的值
var firstLoad = isFirstLoad();
firstLoad(10); // true
firstLoad(10); // false
firstLoad(20); // true

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/100173.html

相關文章

  • javascript作用域和閉包之我見

    摘要:查詢是在作用域鏈中,一級級的往上查找該變量的引用。作用域和作用域鏈作用域的概念,應該兩張圖幾句話就能解釋吧。這個建筑代表程序中的嵌套作用域鏈。一層嵌一層的作用域形成了作用域鏈,變量在作用域鏈中的函數(shù)內(nèi)得到了自己的定義。 javascript作用域和閉包之我見 看了《你不知道的JavaScript(上卷)》的第一部分——作用域和閉包,感受頗深,遂寫一篇讀書筆記加深印象。路過的大牛歡迎指點...

    SoapEye 評論0 收藏0
  • Js基礎知識(三) - 作用域與閉包

    摘要:是詞法作用域工作模式。使用可以將變量綁定在所在的任意作用域中通常是內(nèi)部,也就是說為其聲明的變量隱式的劫持了所在的塊級作用域。 作用域與閉包 如何用js創(chuàng)建10個button標簽,點擊每個按鈕時打印按鈕對應的序號? 看到上述問題,如果你能看出來這個問題實質(zhì)上是考對作用域的理解,那么恭喜你,這篇文章你可以不用看了,說明你對作用域已經(jīng)理解的很透徹了,但是如果你看不出來這是一道考作用域的題目,...

    lemanli 評論0 收藏0
  • Js基礎知識(三) - 作用域與閉包

    摘要:是詞法作用域工作模式。使用可以將變量綁定在所在的任意作用域中通常是內(nèi)部,也就是說為其聲明的變量隱式的劫持了所在的塊級作用域。 作用域與閉包 如何用js創(chuàng)建10個button標簽,點擊每個按鈕時打印按鈕對應的序號? 看到上述問題,如果你能看出來這個問題實質(zhì)上是考對作用域的理解,那么恭喜你,這篇文章你可以不用看了,說明你對作用域已經(jīng)理解的很透徹了,但是如果你看不出來這是一道考作用域的題目,...

    XFLY 評論0 收藏0
  • Js基礎知識(三) - 作用域與閉包

    摘要:是詞法作用域工作模式。使用可以將變量綁定在所在的任意作用域中通常是內(nèi)部,也就是說為其聲明的變量隱式的劫持了所在的塊級作用域。 作用域與閉包 如何用js創(chuàng)建10個button標簽,點擊每個按鈕時打印按鈕對應的序號? 看到上述問題,如果你能看出來這個問題實質(zhì)上是考對作用域的理解,那么恭喜你,這篇文章你可以不用看了,說明你對作用域已經(jīng)理解的很透徹了,但是如果你看不出來這是一道考作用域的題目,...

    tanglijun 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<