JS函數方法Call Apply Bind運用

JS 函數非繼承的call和apply方法

同:call & apply 主要是用于擴展this指向,降低this作用域與函數之間的耦合度;

區別:傳參差異

function.call(this/object,params1,params2,...)
第一個參數為作用域指向參數,后邊參數如過存在多個必須分開書寫
復制代碼
function.apply(this/object,[array]/arguments)
第一個參數為作用域指向參數,后邊參數是一個素組或者參數對象
復制代碼

案列

let name="A";
let b={name:"B"}
function alertInfo(){alert(this.name);
}
alertInfo.call();//彈框 A,this默認指向windows對象
alertInfo.apply();//彈框 A,this默認指向windows對象
復制代碼
let name="A";
let b={name:"B"}
function alertInfo(age){alert(this.name+age);
}
alertInfo.call(b,20);//彈框 B 20,this此時指向b對象
alertInfo.apply(b,20);//彈框 B 20,this此時指向b對象
復制代碼
let name="A";
let b={name:"B"}
function alertInfo(age,sex){alert(this.name+age);
}
alertInfo.call(b,20,'男');//彈框 B 20 男,this此時指向b對象
alertInfo.apply(b,20,'男');//錯誤:該方法接收array或者對象
復制代碼

JS函數bind方法

該方法可用于創建一個函數實例,其this值會被bind綁定至該函數中

案列

let name="A";
let b={name:"B"}
function alertInfo(){alert(this.name);
}
let initF=alertInfo.bind();//創建的函數實例
initF();//彈框 A,this默認指向windows對象
復制代碼
let name="A";
let b={name:"B"}
function alertInfo(){alert(this.name);
}
let initF=alertInfo.bind(b);//創建的函數實例
initF();彈框 B,this此時指向b對象
復制代碼

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/254937.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/254937.shtml
英文地址,請注明出處:http://en.pswp.cn/news/254937.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

IplImage, CvMat, Mat 的關系和相互轉換 再次理解 /(ㄒoㄒ)/~~

opencv中常見的與圖像操作有關的數據容器有Mat,cvMat和IplImage,這三種類型都可以代表和顯示圖像,但是,Mat類型側重于計算,數學性較高,openCV對Mat類型的計算也進行了優化。而CvMat和IplImage類型更側重于“…

HALCON示例程序optical_flow.hdev如何使用optical_flow_mg計算圖像序列中的光流以及如何分割光流。

HALCON示例程序optical_flow.hdev如何使用optical_flow_mg計算圖像序列中的光流以及如何分割光流。 示例程序源碼(加注釋) 關于顯示類函數解釋 dev_update_off () dev_close_window () read_image (Image1, ‘xing/xing000’) dev_open_window_fit_ima…

數字信號處理原理

關于傅里葉變換的解釋,在下面的鏈接:http://blog.jobbole.com/70549/ 。講的挺詳細的: 注意點: 1、信號處理基于這么一個概念,待處理的信號(?)都可以分解為正弦波,不同…

webpack的一些常用配置 (轉)

webpack 的配置文件就是 Node 的一個模塊,它導出的將是一個對象 module.exports {entry: ./entry,output: {path: path.resolve(__dirname, dist),filename: bundle.js} }如果直接使用 webpack 來執行編譯,webpack 默認讀取的是當前目錄下的 webpack.co…

CvMat,Mat和IplImage之間的轉化和拷貝

1、CvMat之間的復制 //注意:深拷貝 - 單獨分配空間,兩者相互獨立 CvMat* a; CvMat* b cvCloneMat(a); //copy a to b 2、Mat之間的復制 //注意:淺拷貝 - 不復制數據只創建矩陣頭,數據共享(更改a,b,c的任意一…

HALCON示例程序particle.hdev測量小圓部分

HALCON示例程序particle.hdev測量小圓部分 示例程序源碼(加注釋) 關于顯示類函數解釋 dev_update_off () dev_close_window () dev_open_window (0, 0, 512, 512, ‘black’, WindowID) set_display_font (WindowID, 14, ‘mono’, ‘true’, ‘false’…

Java List 分頁

//分頁&#xff0c;根據country或者site分br/>Overridepublic List<Integer> getSitesPage(Integer parentLevel, Integer currentPage) {List<Integer> subFrames getSites(parentLevel) ;int currentNum ( currentPage - 1 ) * CardViewUtil.PREPAGE_NUM ;D…

跟多導出數據庫的方法

鏈接&#xff1a;http://www.2cto.com/database/201207/139330.html轉載于:https://www.cnblogs.com/nycj/p/5661151.html

rtp協議詳解/rtcp協議詳解

、簡介 目前&#xff0c;在IP網絡中實現實時語音、視頻通信和應用已經成為網絡應用的一個主流技術和發展方向&#xff0c;本文詳細介紹IP協議族中用于實時語音、視頻數據傳輸的標準協議RTP&#xff08; Real-time Transport Protocol&#xff09;和RTCP&#xff08;RTP Control…

MVC開發中的常見錯誤-04-“System.NullReferenceException”類型的異常在 BBFJ.OA.WebApp.dll 中發生,但未在用戶代碼中進行處理...

未將對象引用設置到對象實例,又名空指針異常,伴隨程序員開發的一生. 查看詳細信息得知: SetUserRoleInfo() 首先想到的是 IBLL.IRoleInfoService RoleInfoService { set; get; }應該是config文件中反射出現了問題 <?xml version"1.0" encoding"utf-8"…

HALCON示例程序pcb_inspection.hdev檢測pcb印刷缺陷

HALCON示例程序pcb_inspection.hdev檢測pcb印刷缺陷 示例程序源碼&#xff08;加注釋&#xff09; 關于顯示類函數解釋 read_image (Image, ‘pcb’) dev_close_window () get_image_size (Image, Width, Height) dev_open_window (0, 0, Width, Height, ‘black’, WindowHa…

profibus GSD文件詳解

profibus GSD文件詳解 2015-6-19 通過PROFIBUS DP用功能塊在主、從站之間實現雙向數據傳送&#xff1a;在主站PLC可以通過調用SFC14“DPRD_DAT”和SFC15“DPWR_DAT”來完成和從站的數據交換&#xff0c;而對于從站來說可以調用FC1“DP_SEND”和FC2“DP_RECV”完成數據的交換。 …

繼承與派生

# 1、什么是繼承&#xff1f;# 繼承一種新建類的的方式&#xff0c;在python中支持一個兒子繼承多個爹# 新建的類稱為子類或者派生類&#xff0c;# 父類又可以稱為基類或者超類## 子類會”遺傳“父類的屬性## 2、為什么要用繼承# 減少代碼冗余## 3、怎么用…

opencv問題解析

錯誤 1 error LNK1123: 轉換到 COFF 期間失敗: 文件無效或損壞 C:\Users\Administ 解決方法如下&#xff1a;項目\屬性\配置屬性\清單工具\輸入和輸出\嵌入清單&#xff1a;原來是“是”&#xff0c;改成“否”。 LINK : fatal error LNK1104: 無法打開文件“opencv_calib3d249…

RTSP協議介紹

1. 實 時流協議RTSP RTSP[3]協 議以客戶服務器方式工作&#xff0c;它是一個多媒體播放控制協議&#xff0c;用來使用戶在播放從因特網下載的實時數據時能夠進行控制&#xff0c;如&#xff1a;暫停/繼 續、后退、前進等。因此 RTSP 又稱為“因特網錄像機遙控協議”。 1.1. …

mysql中出現沒有權限訪問或者查看全部數據庫的問題---用客戶端第一次打開的時候...

在my.cnf中mysqld目錄下的socket/var/lib/mysql/mysql.sock一行下面添加skip_grant_tables---------------報錯退出然后重新啟動server mysqld restart 登錄進去轉載于:https://www.cnblogs.com/yecao8888/p/5661250.html

HALCON示例程序resistor.hdev通過不同焦距圖像提取深度信息

小哥哥小姐姐覺得有用點個贊唄&#xff01; HALCON示例程序resistor.hdev通過不同焦距圖像提取深度信息 示例程序源碼&#xff08;加注釋&#xff09; 關于顯示類函數解釋 Names : [] dev_close_window () for i : 1 to 10 by 1 Names : [Names,‘dff/focus_’ (i$’.2’)…

五軸加工的RTCP技術

五軸加工的RTCP技術【原創整理】 十數年前&#xff0c;一汽為模具加工招標五軸機床&#xff0c;據說當時去了不少國際大牌廠商&#xff0c;招標現場有外商提出他們的產品好&#xff0c;有RTCP功能&#xff0c;在坐的國內廠商和業內專家一時語塞&#xff0c;幾乎無人知曉…

優秀項目解析:區塊鏈上的房地產交易

區塊鏈前哨導語&#xff1a;買房租房中&#xff0c;需要了解多少知識從而規避欺詐風險&#xff1f;如果區塊鏈這一新興技術與房地產這個古老的概念相結合&#xff0c;會碰撞出怎樣的火花&#xff1f;房地產物業的所有權驗證與轉讓將呈現出怎樣的面貌&#xff1f;美國有家科技初…

HALCON示例程序rim.hdev輪圈孔檢測提取字符

小哥哥小姐姐覺得有用點個贊唄&#xff01; HALCON示例程序rim.hdev輪圈孔檢測提取字符 示例程序源碼&#xff08;加注釋&#xff09; 關于顯示類函數解釋 dev_update_off () dev_close_window () dev_open_window (0, 0, 768, 576, ‘black’, WindowID) set_display_font …