javascript一些比較難理解的知識點

来源:http://www.cnblogs.com/ksunone/archive/2017/08/02/7273037.html
-Advertisement-
Play Games

原文出處:https://segmentfault.com/a/1190000010371988 看了一下這篇文章,自己也手敲了一遍 ...


原文出處:https://segmentfault.com/a/1190000010371988

看了一下這篇文章,自己也手敲了一遍

    //1、 立即執行函數   作用:將var變數的作用域限制於函數內,這樣可以避免命名衝突。註意:避免報錯 在開頭加分號

    ;
    (function() {
        console.log("1、立即執行函數")
    })()

    //2、閉包   
    ;
    (function() {
        console.group("2、閉包")

        function f1() {
            var n = 0

            function f2() {
                n++
                console.log("n=" + n)
            }
            return f2
        }
        var result = f1()

        try {
            console.log(n) //undefind 
        } catch(e) {
            //            console.log(e)
        }

        result() //輸出1
        result() //輸出2
        result() //輸出3
        console.groupEnd()
    })()

    //3、使用閉包定義私有變數

    ;
    (function() {
        console.group("3、使用閉包定義私有變數")

        function Pronduct() {
            //            this.name = "mike";
            var name

            this.setName = function(v) {
                name = v
            }
            this.getName = function() {
                return name
            }
        }

        var k = new Pronduct()
        k.setName('amy')
        console.log(k.name) //undefined
        console.log(k.getName()) //輸出amy
        console.groupEnd()
    })()

    //4、prototype
    //每個JavaScript構造函數都有一個prototype屬性,用於設置所有實例對象需要共用的屬性和方法。
    //prototype屬性不能列舉。JavaScript僅支持通過prototype屬性進行繼承屬性和方法。

    ;
    (function() {
        console.group("4.prototype")

        function Rectangle(x, y) {
            this._length = x;
            this._breadth = y;
        }
        Rectangle.prototype.getData = function() {
            return {
                length: this._length,
                breadth: this._breadth
            }
        }
        var x = new Rectangle(3, 4);
        var y = new Rectangle(5, 8);
        console.log(x.getData()) //輸出{length:3,breadth:4}
        console.log(y.getData()) //輸出{length:5,breadth:8}
        console.groupEnd()
    })()

    //5、模塊化
    ;
    (function() {
        console.group("5.模塊化")
        var module = (function() {
            var N = 5;

            function print(x) {
                console.log("The result is:" + x)
            }

            function add(a) {
                var x = a + N;
                print(x)
            }
            return {
                description: "This is descriptione",
                add: add
            }
        })()

        console.log(module.description) //輸出 "This is descriptione"
        module.add(5) //輸出 The result is:10
        console.groupEnd()
    })()

    //6.變數提升

    //JavaScript會將所有變數和函數聲明移動到它的作用域的最前面,這就是所謂的變數提升(Hoisting)。
    //也就是說,無論你在什麼地方聲明變數和函數,
    //解釋器都會將它們移動到作用域的最前面。因此我們可以先使用變數和函數,而後聲明它們。

    //7、柯里華
    //柯里化,即Currying,可以是函數變得更加靈活。我們可以一次性傳入多個參數調用它;
    //也可以只傳入一部分參數來調用它,讓它返回一個函數去處理剩下的參數。
    ;
    (function() {
        console.group('7.柯里華')
        var add = function(x) {
            return function(y) {
                return x + y;
            }
        }
        console.log(add(1)(1)) //輸出2
        var add1 = add(1)
        console.log(add1(2)) //輸出3
        var add10 = add(10)
        console.log(add10(2)) //輸出12
        console.groupEnd()
    })()

    //8.apply,call與bind方法
    //call  指定this值調用函數
    ;
    (function() {
        console.group('8.apply,call與bind方法')
        var user = {
            name: "mike",
            whatIsYourName: function() {
                console.log(this.name)
            }

        }
        console.group("call")
        user.whatIsYourName() //輸出 mike

        var user2 = {
            name: "amy"
        }
        user.whatIsYourName.call(user2) //輸出amy
        console.groupEnd()

        //apply apply方法與call方法類似。兩者唯一的不同點在於,apply方法使用數組指定參數,而call方法單獨指定:
        ;
        (function() {
            console.group('apply')
            var user = {
                greet: "hello",
                greetUser: function(userName, name) {
                    console.log(this.greet + " " + userName + ' ' + name)
                }
            }
            var user2 = {
                greet: "hey"
            }

            user.greetUser.call(user2, 'mike', "ak") //輸出 hey mike ak
            user.greetUser.apply(user2, ['amy', "ak"]) //輸出 hey amy ak
            console.groupEnd()
        })()
        //bind 
        ;
        (function() {
            console.group('bind')
            var user = {
                greet: "Hello!",
                greetUser: function(userName) {
                    console.log(this.greet + " " + userName);
                }
            };

            var greetHola = user.greetUser.bind({
                greet: "Hola"
            });
            var greetBonjour = user.greetUser.bind({
                greet: "Bonjour"
            });

            greetHola("Rahul") // 輸出"Hola Rahul"
            greetBonjour("Rahul") // 輸出"Bonjour Rahul"
            user.greetUser('mike')
            console.groupEnd()
        })()

    })()
    
    

 


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

-Advertisement-
Play Games
更多相關文章
  • 背景 環境需要設置代理才能夠訪問外部網路,如果只是運行java程式來訪問網路,我們可以通過java jar test.jar DproxyHost=proxy_ip DproxyPort=proxy_port,但如果是java的maven項目中,單元測試需要訪問網路,只執行mvn test則會導致單 ...
  • 公司的項目底層,是使用的TCP,因為可靠,自動斷線重連,在底層都實現了,但是我記得TCP也會有掉包的問題,所以這文章就誕生了——關於TCP掉包的問題,TCP是基於不可靠的網路實現可靠的傳輸,肯定也會存在掉包的情況。 如果通信中發現缺少數據或者丟包,那麼,最大的可能在於程式發送的過程或者接收的過程出現 ...
  • 這一章主要介紹什麼是[BX]以及loop(迴圈)指令怎麼使用,loop和[BX]又怎麼樣相結合,段首碼又是什麼鬼,以及如何使用段首碼。 1、[BX]的概念 [BX]和[0]類似,[0]表示記憶體單元的偏移地址是0。要完整描述一個記憶體單元,需要兩種信息:記憶體單元的地址,記憶體單元的長度(類型)。[BX]同 ...
  • 不久前參與開發了一個基於dubbo分散式框架的底層賬單系統,並實現了其中的一部分業務介面,目前需對這些介面進行壓測,以評估生產環境所能承受的最大吞吐量。筆者以其中一個查詢介面為例來回顧此次壓測的整體流程。 壓測準備: 1.調用查詢介面的測試jar包,作為dubbo-consumer,依賴了查詢服務的 ...
  • 架構好文學習,攢~~ 京東咚咚架構演進 -- By 【瞬息之間】 名詞解釋: Apache MINA: 百度百科 HAProxy: 百度百科 1.0 架構筆記: 優點:模型結構簡單 理解起來簡單;開發起來簡單;部署起來也簡單。 缺點:效率和擴展 這個模型實際上是一個高功耗低效能的模型,不活躍的連接在 ...
  • 簡單工廠模式,就是有一個工廠類,負責生成所需要的實體類。 這讓我想起了紅警,在紅警里,如果需要造一輛坦克,需要先有一個戰車工廠,在坦克工廠里選擇坦克類型,然後坦克工廠才會生成所需要的坦克。 不多說直接上代碼。 首先有個坦克類Panzer(哈哈我的俠盜獵車似乎就記得這麼一個作弊秘籍了) 有兩個類型的坦 ...
  • 在我前面有很多篇隨筆介紹了Web API 介面層的架構設計,以及對微信公眾號、企業號、小程式等模塊的分類劃分。例如在《C#開發微信門戶及應用(43)--微信各個項目模塊的定義和相互關係》介紹了相關模塊的劃分,在《基於微信小程式的系統開發準備工作》介紹了Web API的架構設計思路。本篇隨筆對之前介紹... ...
  • 參考連接:http://nqdeng.github.io/7-days-nodejs/#1.1 NodeJS基礎 什麼是NodeJS JS是腳本語言,腳本語言都需要一個解析器才能運行。對於寫在HTML頁面里的JS,瀏覽器充當瞭解析器的角色。而對於需要獨立運行的JS,NodeJS就是一個解析器。 每一 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...