js學習總結----call和apply和bind的區別

来源:http://www.cnblogs.com/diasa-fly/archive/2017/06/28/7090997.html
-Advertisement-
Play Games

apply和call的方法是一模一樣的,都是用來改變方法的this關鍵字,並且把方法執行:而且在嚴格模式和非嚴格模式下對於第一個參數是null/undefined這種情況的規律是一樣的; bind:這個方法在IE6-8下不相容 ->和call和apply類似都是用來改變this關鍵字的 ...


apply和call的方法是一模一樣的,都是用來改變方法的this關鍵字,並且把方法執行:而且在嚴格模式和非嚴格模式下對於第一個參數是null/undefined這種情況的規律是一樣的;

bind:這個方法在IE6-8下不相容 ->和call和apply類似都是用來改變this關鍵字的

'use strict' //告訴當前瀏覽器接下來的js代碼將按照嚴格模式進行編寫
        var obj = {name:'張三'}
        function fn(num1,num2){
            console.log(num1+num2);
            console.log(this)
        }
        fn(100,200);//this ->window num1=100 num2=200
        fn.call(100,200);// this->100 num1 = 200 num2=undefined  NaN
        fn.call(obj,100,200)//this->obj  call在給fn傳遞參數的時候,是一個個傳遞值的,而apply不是一個個傳,而是把要傳遞的參數值放在一個數組中進行操作。但是也相當於一個個的給fn的形參賦值
        fn.apply(obj,[100,200]);//
        //預處理:事先把fn的this改變為我們想要的結果,並且把對應的參數值也準備好,以後要用到了,直接的執行即可。bind這裡實現了預處理的效果
        var tempFn = fn.bind(obj,100,200);//只是改變了fn中的this為obj,並且給fn傳遞了兩個參數值100和200,但此時並沒有把fn這個函數執行,執行bind會有一個返回值,這個返回值tempFn就是我們把fn的this改變後的那個結果
        tempFn();
        fn.call();//this->window  在嚴格模式下this->undefined
        fn.call(null);//this->window 在嚴格模式下this->null
        fn.call(undefined)//this->window 在嚴格模式下this->undefined

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

-Advertisement-
Play Games
更多相關文章
  • rem由來:font size of the root element,那麼rem是個單位,單位大小由它第一代老祖宗的font-size的大小決定。現在前端碼農們為了能在各個屏幕上看到一個健康的網頁在默默的犧牲著自己的健康,因為不僅要知道rem是個單位,更重要的是要知道怎麼能在不同解析度下呈現的頁面 ...
  • 在圖片比較多的網站總會看見,當瀏覽到那個位置,就載入那的圖片。 ...
  • 簡介 貝塞爾曲線是可以做出很多複雜的效果來的,比如彈跳球的複雜動畫效果,首先加速下降,停止,然後彈起時逐漸減速的效果。 使用貝塞爾曲線常用的兩個網址如下: 緩動函數:http://www.xuanfengge.com/easeing/easeing/ cubic-bezier:http://cubi ...
  • 1.如何使用vuex來保存數據(需要傳參的情況下) 實例說明:登錄->緩存用戶信息->跳轉到首頁->從state獲取用戶信息顯示在頁面上 step1: 新建store.js作為初始化vuex的主文件,可在裡面創建state對象,緩存數據欄位,初始化vuex, 目錄結構如下: store.js代碼如下 ...
  • 如果你是一個人在自學前端開發,或者是對前端開發有比較濃厚的興趣正想踏入前端領域,只要你在前端自學路上遇到了自己無法解決的技術難題,那麼儘管將你的疑惑交給我的小伙伴兒們吧,我們都是一群在前端自學路上摸爬滾打的有志青年,希望你可以來和我們共同交流。同時也希望你能獻出自己的一份力,幫助我的小伙伴兒們解決他 ...
  • 一. 簡介 一個用於顯示多種不同類型圖片的React組件,包括網路圖片、靜態資源、臨時的本地圖片、以及本地磁碟上的圖片(如相冊)等。從0.14版本開始,React Native提供了一個統一的方式來管理iOS和Android應用中的圖片。要往App中添加一個靜態圖片,只需把圖片文件放在代碼文件夾比如 ...
  • 菜單導航,《JS面向對象筆記一》, 參考書籍:阮一峰之《JavaScript標準參考教程》 一、構造函數和new命令 二、this關鍵字 三、構造函數和new命令 四、構造函數和new命令 五、構造函數和new命令 六、構造函數和new命令 七、構造函數和new命令 八、構造函數和new命令 一、構 ...
  • 方法一: 分別獲取所需數據元素,DOM結構外層不用包form標簽(適用於數據量少,數據元素分散於整個頁面) 方法二: 需要包裹form標簽(適用於數據量大,元素集中) html代碼: ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...