国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

JavaScript中的apply()方法和call()方法使用介紹

2024-05-06 14:21:32
字體:
來源:轉載
供稿:網友
1、每個函數都包含兩個非繼承而來的方法:apply()和call()。
2、他們的用途相同,都是在特定的作用域中調用函數。
3、接收參數方面不同,apply()接收兩個參數,一個是函數運行的作用域(this),另一個是參數數組。
call()方法第一個參數與apply()方法相同,但傳遞給函數的參數必須列舉出來。
  例1:
代碼如下:
window.firstName = "diz";
window.lastName = "song";
var myObject = { firstName: "my", lastName: "Object" };
function HelloName() {
  console.log("Hello " + this.firstName + " " + this.lastName, " glad to meet you!");
}
HelloName.call(window); //huo .call(this);
HelloName.call(myObject);

  運行結果為:
Hello diz song glad to meet you!
Hello my Object glad to meet you!
  例2:
代碼如下:
function sum(num1, num2) {
return num1 + num2;
}
console.log(sum.call(window, 10, 10)); //20
console.log(sum.apply(window,[10,20])); //30

  分析:在例1中,我們發現apply()和call()的真正用武之地是能夠擴充函數賴以運行的作用域,如果我們想用傳統的方法實現,請見下面的代碼:
代碼如下:
window.firstName = "diz";
window.lastName = "song";
var myObject = { firstName: "my", lastName: "Object" };
function HelloName() {
console.log("Hello " + this.firstName + " " + this.lastName, " glad to meet you!");
}
HelloName(); //Hello diz song glad to meet you!
myObject.HelloName = HelloName;
myObject.HelloName(); //Hello my Object glad to meet you!

  見加紅的代碼,我們發現,要想讓HelloName()函數的作用域在對象myObject上,我們需要動態創建myObject的HelloName屬性,此屬性作為指針指向HelloName()函數,這樣,當我們調用myObject.HelloName()時,函數內部的this變量就指向myObjecct,也就可以調用該對象的內部其他公共屬性了。
  通過分析例2,我們可以看到call()和apply()函數的真正運用之處,在實際項目中,還需要根據實際靈活加以處理!
  一個小問題:再看一看函數中定義函數時,this變量的情況
代碼如下:
function temp1() {
console.log(this); //Object {}
function temp2() {
console.log(this); //Window
}
temp2();
}
var Obj = {};
temp1.call(Obj); //運行結果見上面綠色的注釋!!!!

  執行結果與下面的相同:
代碼如下:
function temp1() {
console.log(this);
temp2();
}
function temp2() {
console.log(this);
}
var Obj = {};
temp1.call(Obj);

4、bind()方法
  支持此方法的瀏覽器有IE9+、Firefox4+、Safari5.1+、Opera12+、Chrome。它是屬于ECMAScript5的方法。直接看例子:

代碼如下:
window.color = "red";
var o = { color: "blue" };
function sayColor(){
alert(this.color);
}
var OSayColor = sayColor.bind(o);
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 五大连池市| 隆化县| 泌阳县| 金山区| 赤壁市| 宁陕县| 疏勒县| 海原县| 墨玉县| 甘南县| 凯里市| 明光市| 忻城县| 抚松县| 霍山县| 邳州市| 修水县| 安溪县| 青阳县| 奉贤区| 门源| 德令哈市| 手机| 南充市| 巨野县| 东乌珠穆沁旗| 开阳县| 全州县| 静海县| 通城县| 郧西县| 石阡县| 临高县| 阆中市| 开鲁县| 余庆县| 同仁县| 手游| 长阳| 西宁市| 平利县|