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

首頁 > 語言 > JavaScript > 正文

javascript中bind函數的作用實例介紹

2024-05-06 16:09:15
字體:
來源:轉載
供稿:網友
bind()的方法在ie,6,7,8中不適用,需要擴展通過擴展Function prototype可以實現此方法,下面為大家介紹下javascript中bind函數的作用

<!DOCTYPE html><html><head><meta charset="utf-8"><style>button {background-color:#0f0;}</style></head><body><button> 按鈕 </button><input type="text"><script>var button = document.getElementById("button");button.onclick = function() {alert(this.id); // 彈出button};//可以看出上下文的this 為button</script></body></html>

此時加入bind

復制代碼 代碼如下:


 var text = document.getElementById("text");
 var button = document.getElementById("button");
 button.onclick = function() {
 alert(this.id); // 彈出button
 }.bind(text);
 //可以看出上下文的this 為button

此時會發(fā)現this改變?yōu)閠ext

函數字面量里也適用,目的是保持上下指向(this)不變。

var obj = {color: "#ccc", element: document.getElementById('text'),events: function() {document.getElementById("button").addEventListener("click", function(e) {console.log(this);this.element.style.color = this.color;}.bind(this))return this;},init: function() {this.events();}};obj.init();

此時點擊按鈕text里的字會變色。可見this不為button而是obj。

bind()的方法在ie,6,7,8中不適用,需要擴展通過擴展Function prototype可以實現此方法。

if (!Function.prototype.bind) {Function.prototype.bind = function(obj) {var slice = [].slice, args = slice.call(arguments, 1), self = this, nop = function() {}, bound = function() {return self.apply(this instanceof nop ? this : (obj || {}),args.concat(slice.call(arguments)));};nop.prototype = self.prototype;bound.prototype = new nop();return bound;};}

此時可以看到ie6,7,8中也支持bind()。

復制代碼 代碼如下:


slice = Array.prototype.slice,



array = Array.prototype.slice.call( array, 0 );


將類似數組轉換為數組

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 西贡区| 大余县| 乌兰浩特市| 惠州市| 兴文县| 东安县| 淮北市| 石楼县| 当阳市| 定西市| 淮北市| 湄潭县| 白朗县| 建平县| 伊金霍洛旗| 塘沽区| 宁蒗| 石渠县| 绿春县| 滦南县| 垣曲县| 根河市| 汽车| 九龙坡区| 分宜县| 木里| 汝阳县| 甘德县| 遂昌县| 青龙| 保康县| 武宣县| 泸西县| 安岳县| 壤塘县| 通化县| 合水县| 鹿泉市| 尖扎县| 霞浦县| 台江县|