您的位置:知识库 » Web前端

Javascript学习笔记十三——关于响应事件

作者: 飞林沙  来源: 博客园  发布时间: 2010-01-25 13:13  阅读: 2294 次  推荐: 1   原文链接   [收藏]  

系列文章导航:

JavaScript学习笔记一——数据类型

JavaScript学习笔记二——函数

JavaScript学习笔记三——作用域

JavaScript学习笔记四——Eval函数

JavaScript学习笔记五——类和对象

JavaScript学习笔记六:prototype的提出

Javascript学习笔记七——原型链的原理

Javascript学习笔记八——用JSON做原型

Javascript学习笔记九——prototype封装继承

Javascript学习笔记十——网页运行原理

Javascript学习笔记十一——包装DOM对象

Javascript学习笔记十三——关于响应事件

Javascript学习笔记十二——Ajax入门


具体的事情记不清了,某一天下班后听到两个同事在说关于关于事件的问题。

这里简单说下:

<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
0
标签:JavaScript

Web前端热门文章

    Web前端最新文章

      最新新闻

        热门新闻