HTML事件处理程序---内联onclick事件

  HTML事件处理程序绑定方法:

<input type="button" value="click me" οnclick="show(this,type,event)">    ---代码1   // 点击按钮谷歌下输出:[input, "button", MouseEvent]

  事件在DOM之前定义:

function show() {              ---代码2
  console.log(Array.prototype.slice.call(arguments));
}

  

  之前一直朦朦胧胧,不知道onclick中绑定的show事件是怎么传参数的~~~

  show事件一般我们知道的是可以传两个参数:this和event,分别是绑定的这个DOM对象、发生的事件

  但是这种绑定事件的原理实际上是这样的:

function(){             ---代码3
  with(document){
    with(this){
      // 元素属性值
    }
  }
}

  在代码1中,我传了type参数,实际上访问的正好是this.type,就是当前DOM元素的type属性。DOM0级绑定事件的原理就是代码3描述的,综合起来可能就类似这样:

  传递的参数a,先在this中找,即this.a,如果未定义,就在document中找,找不到就报错

function show() {               ---代码4
  with(document){
    with(this){
      // 元素属性值
      // 实际操作代码
    }
  }
}

  代码1中传的第1个参数this,这个不用说,都知道是当前的DOM对象;第2个参数type,就是会在this中找,看this有没有这个属性,没有的话,就在document中找;第3个参数就是事件对象。函数里传参的顺序和内容可以随便改变的。

  ------------------------------第2种情况-----------------------------------

  就是表单情况:

<form action="">       ---代码5
  <input type="text" name="username">
  <input type="button" value="click me" this="32" event="sd" οnclick="show(this,getAttribute('this'),type,event,getAttribute('event'),username.value)">  

// 点击按钮谷歌下输出:[input, "32", "button", MouseEvent, "sd",""]
</form>

  表单情况会增加一层逻辑,就是this.form:

function(){
  with(document){
    with(this.form){
      with(this){
        // 元素属性值
        // 处理代码
      }
    }
  }
}

  在代码5中,先说说username.value这个参数,就是表单中可访问的一个作用域this.form。传入参数会先看this有没有定义该属性,有就传入,没有的话,就在this.form中找,没有的话,最后在document中找。

  另外,我故意在DOM上写了this、event的属性,看怎么样才能访问,会不会影响默认的this、event。验证后发现,自定义的属性只能通过getAttribute函数获取到(做这个验证只能说明我的js不扎实o(╥﹏╥)o)

转载于:https://www.cnblogs.com/molinglan/p/8707863.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值