zoukankan      html  css  js  c++  java
  • 事件绑定

    事件绑定

    1、什么是事件绑定

    所谓的事件绑定就是为某个对象的某个事件绑定相应的事件处理程序,我们把这个过程就称之为"事件绑定"。

    2、事件绑定的三种形式

    ① 行内绑定

    ② 动态绑定

    ③ 事件监听

    3、行内绑定

    基本语法:<标签         属性列表…      事件="事件的处理程序" />

    由此可知:咱们刚才在常用Javascript事件中演示的都是通过行内绑定实现的。

     

    例1:点击div元素,实现更换元素的背景颜色

    通过以上形式的绑定(行内绑定)就可以完成相关功能。

     

    面试题:你会不会写结构+样式+行为相分离的代码?

    结构:HTML代码

    样式:CSS代码

    行为:Javascript代码

    4、动态绑定

    例2:使用结构+样式+行为相分离的思想改进例1

    要用到的知识点:动态绑定,基本语法:

    dom对象.事件 = 事件的处理程序(通常是一个函数)

    什么是dom对象?

    在Javascript中,通过document方式获取的对象都是dom对象。

    以上程序可以完成对结构+样式+行为的分离,其实以上程序还可以进一步简化为如下形式:

    5、行内绑定与动态绑定的区别

    在Javascript中,存在一个特殊的对象this,其随着运行环境的不同,其指向也是不同的。

    1)行内绑定中的this指向:

    运行结果:直接报错,提示this.style为空或不是对象,使用调试工具显示如下:

    IE调试几步走:

    ① 在认为可能出错的位置下一个断点

    ② 启动调试,单击页面中的程序触发代码的执行,直到出现黄色的小箭头

    ③ 在右侧监视窗口,写入要监管的变量或对象

    通过以上调试可以得出一个结论:在行内绑定中其内部的this指向全局window对象

    <div onclick = 'display();'></div>相当于<div onclick = 'window.display();'></div>,记住这样一句话:在Javascript中,谁调用了这个函数,其函数内部的this就指向谁。

     

    特别说明:在Javascript中,所有的全局变量或函数都是以属性形式添加到window对象中,如下图所示:

    2)动态绑定中的this指向

    要使用到的知识点:封装一个$函数,用于获取指定id的dom对象

    编写代码,测试动态绑定中的this指向:

    由以上案例运行结果可以得出结论:动态绑定中其处理程序内部的this指向了当前正在操作的dom对象。

     

    综上所述:

    行内绑定中,其内部的this指向了全局window对象

    动态绑定中,其内部的this指向了正在操作的dom对象

  • 相关阅读:
    hdu 思维风暴
    HDU 4183Pahom on Water(网络流之最大流)
    现在仍在工作的12名最“屌”的程序猿
    安卓ContentObserver模式获取短信用正则自己主动填充验证码
    Android插件实例——360 DroidPlugin具体解释
    mysql---union的使用方法
    SICP 习题 (2.11)解题总结:区间乘法的优化
    jQuery中的ajax
    Ajax的简单总结
    jQuery插件开发
  • 原文地址:https://www.cnblogs.com/nyxd/p/5364393.html
Copyright © 2011-2022 走看看