标签:listener html assert argument 调用 var lis ntb 改变
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <button id="test">click me</button> </body> <script> function bind(context,name){ return function(){ return context[name].apply(context,arguments); //用apply函数改变函数的上下文,apply函数的第一个参数就是我们需要的上下文对象。 } }; /*对比一下*/ //function bind(context){ //self = this; //保存this,即调用bind方法的目标函数 //return function(){ // return self.apply(context,arguments); //}; //}; var button = { clicked: false, click: function(){ this.clicked = true; console.assert(button.clicked,"The button has been clicked."); console.log(this); } }; var elem = document.getElementById("test"); elem.addEventListener("click",bind(button,"click"),false); //调用bind方法,bind方法的第一个参数就是我们需要的上下文对象; //addEventListener()三个参数,分别是event,function,false </script> </html>
标签:listener html assert argument 调用 var lis ntb 改变
原文地址:http://www.cnblogs.com/Jerry-spo/p/6437789.html