系列文章导航:
Javascript学习笔记九——prototype封装继承
具体的事情记不清了,某一天下班后听到两个同事在说关于关于事件的问题。
这里简单说下:
<input type="button" runat="server" value="Click Me" id="ButtonTest" />
很普通的一个按钮,我们要为其添加点击事件,有两种方法:
A.
<input type="button" runat="server" onclick="Alert()" value="Click Me" id="ButtonTest" /> <script type="text/javascript"> function Alert() { alert("Click Me"); } script>
B.
<input type="button" runat="server" value="Click Me" id="ButtonTest" /> <script type="text/javascript"> document.getElementById("ButtonTest").onclick = function () { alert("Click Me"); } script>
我们称A方法为静态绑定,B方法为动态绑定。我们来看A方法,他近乎可等于这样的效果:
<input type="button" runat="server" onclick="Alert()" value="Click Me" id="ButtonTest" /> <script type="text/javascript"> document.getElementById("ButtonTest").onclick = function () { Alert(); } script>
也就是说,当我们静态绑定一个事件的时候,实际上是系统默认为我们做了一个匿名函数,然后把我们的方法体包于其中。由于这样,就涉及到了this的问题。
我们来看这样一段代码,这也是我在公司初学JS的时候,公司的JS小牛抛给我的问题。
<input type="button" runat="server" onclick="Alert1()" value="Test1" id="ButtonTest1" /> <input type="button" runat="server" onclick="Alert2(this)" value="Test2" id="ButtonTest2" /> <script type="text/javascript"> function Alert1() { alert(this.value); } function Alert2(obj) { alert(obj.value); } script>
当试验这样一段代码时,便会发现第一个按钮会弹出”undefined”,第二个按钮弹出”Test2”。原因就是如我上面所说,在按钮一中,方法等于声明了一个匿名函数,然后讲Alert1()闭包于其中,也就是说,Alert1()是无法找到其调用者的,所以这时,他会去找window对象的value属性,结果发现未定义,我们可以这样证明:
<input type="button" runat="server" onclick="Alert1()" value="Test1" id="ButtonTest1" /> <input type="button" runat="server" onclick="Alert2(this)" value="Test2" id="ButtonTest2" /> <script type="text/javascript"> value = "window"; function Alert1() { alert(this.value); } function Alert2(obj) { alert(obj.value); } script>
运行上面的代码,就可以很好地理解问题了!
1.本站内容仅供参考,不作为任何法律依据。用户在使用本站内容时,应自行判断其真实性、准确性和完整性,并承担相应风险。
2.本站部分内容来源于互联网,仅用于交流学习研究知识,若侵犯了您的合法权益,请及时邮件或站内私信与本站联系,我们将尽快予以处理。
3.本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
4.根据《计算机软件保护条例》第十七条规定“为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬。”您需知晓本站所有内容资源均来源于网络,仅供用户交流学习与研究使用,版权归属原版权方所有,版权争议与本站无关,用户本人下载后不能用作商业或非法用途,需在24个小时之内从您的电脑中彻底删除上述内容,否则后果均由用户承担责任;如果您访问和下载此文件,表示您同意只将此文件用于参考、学习而非其他用途,否则一切后果请您自行承担,如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。
5.本站是非经营性个人站点,所有软件信息均来自网络,所有资源仅供学习参考研究目的,并不贩卖软件,不存在任何商业目的及用途
暂无评论内容