閉包和js事件執行機制簡介

来源:https://www.cnblogs.com/webwjg/archive/2020/06/12/13098946.html
-Advertisement-
Play Games

最近碰到了關於閉包的問題,查看資料總結下我眼中的閉包 var price=document.getElementsByTagName('div'); for (var i = 0; i < 6; i++) { price[i].onClick=function () { console.log(i) ...


最近碰到了關於閉包的問題,查看資料總結下我眼中的閉包

var price=document.getElementsByTagName('div');
for (var i = 0; i < 6; i++) {
    price[i].onClick=function () {
        console.log(i)
    }
}  // 6 6 6 6 6 6
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

先瞭解下js的執行機制,這裡涉及了JS中單線程的概念。由於JS是單線程語言,不存在併發執行的任務,所有任務都需要排隊,前一個任務結束,才會開始下一個任務。因此,在JS中,任務分為兩種,一是同步任務,一是非同步任務。而for迴圈就是同步任務,點擊事件函數是非同步任務,非同步任務會去排隊,排到同步任務的後面(大家猜猜如果幾個非同步任務排隊順序是怎樣的),ok !
現在代碼其實可以等於

var price=document.getElementsByTagName('div');
for (var i = 0; i < 6; i++) {
	price[i].onClick=order();
}  
fnction order(){
    console.log(i)
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

然後瞭解什麼是閉包,我理解的閉包就是在函數這個作業域里引用作用域之外的量,閉包有個特點就是–基於詞法作用域的查找規則(當前找不到某個變數,就向上查找,如果最終沒有找到,則返回undefined)。
所以,order()中的 i 就成了6,好了,小伙伴們瞭解了吧

,

                                </div><div data-report-view="{&quot;mod&quot;:&quot;1585297308_001&quot;,&quot;dest&quot;:&quot;https://blog.csdn.net/weixin_44989478/article/details/105594964&quot;,&quot;extend1&quot;:&quot;pc&quot;,&quot;ab&quot;:&quot;new&quot;}"><div></div></div>
            <link href="https://csdnimg.cn/release/phoenix/mdeditor/markdown_views-60ecaf1f42.css" rel="stylesheet">
                            </div>
</article>

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Vue 3尚未正式發佈,但是維護者已經發佈了Beta版本,供我們的參與者嘗試並提供反饋。 如果你想知道Vue 3的主要功能和主要變化是什麼,那麼我將在這篇文章中重點介紹一下,告訴你使用Vue 3 beta 9創建一個簡單的應用程式。 我將介紹儘可能多的新內容,包括fragments,teleport ...
  • 0. 前言 也許我們通過 jquery 的迴圈方法進行數組遍歷,但是當不符合條件時,怎麼跳出當前迴圈?(即用each方法內,當不滿足條件時想break跳出迴圈體,想continue繼續執行下一個迴圈遍歷),我們經常會習慣JS中的break何continue,但是使用之後沒有效果,因為在JQuery中 ...
  • Webpack 5的模塊聯邦提供載入部分編譯好的代碼能力,這個似乎會成為微前端架構的標準實現。 Webpack只是我分享的一小點,我是08年出道的高級前端架構師,有問題或者交流經驗可以進我的扣扣裙 519293536 我都會儘力幫大家哦 引言 在當前的微前端實現中,我們需要通過一系列的技巧去實現。正 ...
  • 摘要 數據是我們每天都在接觸的東西,我們需要清晰的瞭解去瞭解數據的變化趨勢,就需要讓數據可視化。最近在接觸學習antd的社區精選組件,上一篇文章主要是講了高德地圖的應用,這次我們就來分享下G2Plot在react中實現可視化數據圖表的簡單應用。 Ant Design Charts的使用方法 安裝 n ...
  • 摘要 平常生活中,地圖導航是必不可少的,最近在學習Ant Design,瞭解了下社區的精選組件,看到了與地圖相關的精品組件庫,高德地圖組件庫。所以記錄下這次高德地圖的使用心得,既可以提升自己的業務多樣性,也可以分享給需要的小伙伴。 React-Amap用法 安裝 npm install --save ...
  • 本文主要介紹如何通過CLI命令行(也就是終端或者cmd打開的那個shell視窗)實現 js和 css 的合併壓縮。 uglifyjs 合併壓縮 js: 1.安裝node 這一步就不多說了,下載node自行安裝。 2.安裝 uglifyjs 全局安裝: npm install -g uglify-js ...
  • 一. 普通對象與函數對象 JavaScript 中,萬物皆對象!但對象也是有區別的。分為普通對象和函數對象,Object 、Function 是 JS 自帶的函數對象。下麵舉例說明 var o1 = {}; var o2 =new Object(); var o3 = new f1(); ​ fun ...
  • # 從零開始的前端生活--盒尺寸 padding padding對塊級元素的影響 css中預設的box-sizing 是content-box,使用padding會額外增加元素的尺寸。 當padding足夠大,把width擠沒掉了,這時width就無效。裡面的內容表現為“首選最小寬度” 首選最小寬 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...