O(∩_∩)O~~又是新的一周开始了,今天还是在继续学习Javascript知识,今天主要讲了事件的知识。现在就总结下吧。
事件
事件一般是用于浏览器和用户操作进行交互。最早是 IE 和 Netscape Navigator 中出现,作为分担服务器端运算负载的一种手段。 直到几乎所有的浏览器都支持事件处理。 而 DOM2级规范开始尝试以一种复合逻辑的方式标准化 DOM 事件。IE9、Firefox、Opera、Safari 和Chrome 全都已经实现了“DOM2 级事件”模块的核心部分。IE8 之前浏览器仍然使用其专有事件模型。
JavaScript 有三种事件模型:内联模型、脚本模型和 DOM2 模型.
内联模型:传统接单的一种处理事件的方法,和 HTML 混写的,并没有与 HTML 分离。
在 HTML 中把事件处理函数作为属性执行 JS 函数
<input type="button" value="按钮" onclick="box();" /> //执行 JS 的函数 //函数不得放到 window.onload 里面,这样就看不见了
脚本模型:由于内联模型违反了 HTML 与 JavaScript 代码层次分离的原则。为了解决这个问题, 我们可以在 JavaScript 中处理事件。这种处理方式就是脚本模型。
<script> window.onload = function () { var input = document.getElementsByTagName('input')[0]; //得到input对象 input.onclick = function () { //匿名函数执行 alert('Lee'); }; }; </script>
注:通过匿名函数,可以直接触发对应的代码。也可以通过指定的函数名赋值的方式来执行函数(赋值的函数名不要跟着括号) input.onclick = box; //把函数名赋值给事件处理函数
事件处理函数:JavaScript 可以处理的事件类型为:鼠标事件、键盘事件、HTML 事件。
注: 所有的事件处理函数都会都有两个部分组成, on + 事件名称,例如click的事件处理函数是onclick
鼠标事件:页面所有元素都可触发
<script> window.onload = function () { //鼠标单击事件(第一种写法) document.getElementsByName("name")[0].onclick = function () {
alert(this.value);
//鼠标单击事件(第二种写法,可以把方法单独拿出来写,最后赋值)
function click() {
alert(this.value); }
document.getElementsByName("name")[1].onclick = click; } }; }; </script>
<body>
<form>
<input type="button" name="name" value="点击"/><br /><br />
<input type="button" name="name" value="点击函数执行" /><br /><br />
</form>
</body>
input.ondblclick = function () { alert(this.value); };
input.onmousedown = function () { alert(this.value); };
input.onmouseup = function () { alert(this.value); };
input.onmouseover = function () { alert(this.value); };
input.onmouseout = function () { alert(this.value); };
input.onmousemove = function () { alert(this.value); };
键盘事件:
keydown:当用户按下键盘上任意键触发,如果按住不放,会重复触发
keypress:当用户按下键盘上的字符键触发,如果按住不放,会重复触发
keyup:当用户释放键盘上的键触发
HTML事件:
window.onload = function () { alert(‘Hello World’); };
window.onunload = function () { alert('Hello World'); };
input.onselect = function () { alert('Hello World'); };
input.onchange = function () {
alert('Hello World');
};
input.onfocus = function () { alert('Hello World'); };
input.onblur = function () { alert('Hello World'); };
form.onsubmit = function () { alert('Hello World'); }
form.onreset= function () { alert('Hello World'); }
事件对象:事件处理函数的一个标准特性是, 以某些方式访问的事件对象包含有关于当前事件的上下文信息。
事件处理三部分组成:对象.事件处理函数=函数
例:单击文档任意处
<script> document.onclick = function () { alert('Lee'); }; </script>
注:以上程序的名词解释:click 表示一个事件类型,单击。onclick 表示一个事件处理函数或绑定对象的属性(或者叫事件监听器、侦听器)。document 表示一个绑定的对象,用于触发某个元素区域。function()匿名函数是被执行的函数,用于触发后执行。
除了用匿名函数的方法作为被执行的函数,也可以设置成独立的函数
document.onclick = SayHi; //直接赋值函数名即可,无须括号 function SayHi() { alert('Hello World'); }
事件对象,我们一般称作为 event 对象,这个对象是浏览器通过函数把这个对象作为参数传递过来的。
function SayHi() { //普通空参函数 alert(arguments.length); //没有得到任何传递的参数 }
input.onclick = function () { //事件绑定的执行函数 alert(arguments.length); // 得到一个隐藏参数 };
通过上面两组函数中, 我们发现, 通过事件绑定的执行函数是可以得到一个隐藏参数的。说明,浏览器会自动分配一个参数,这个参数其实就是 event 对象。
上面这种做法比较累,那么比较简单的做法是,直接通过接收参数来得到即可。
input.onclick = function (evt) { //接受 event 对象,名称不一定非要 event var e = evt || window.event; //实现跨浏览器兼容获取 event 对象 alert(e); //MouseEvent,鼠标事件对象 };
事件流
事件流是描述的从页面接受事件的顺序,当几个都具有事件的元素层叠在一起的时候,那么你点击其中一个元素, 并不是只有当前被点击的元素会触发事件, 而层叠在你点击范围的所有元素都会触发事件。事件流包括两种模式:冒泡和捕获。
事件冒泡, 是从里往外逐个触发。(默认)
事件捕获, 是从外往里逐个触发。
document.onclick = function () { alert('我是 document'); }; document.documentElement.onclick = function () { alert('我是 html'); }; document.body.onclick = function () { alert('我是 body'); }; document.getElementById('box').onclick = function () { alert('我是 div'); }; document.getElementsByTagName('input')[0].onclick = function () { alert('我是 input'); };
上面这个例子,是这样执行的:
阻止事件冒泡:
function stopPro(evt) { var e = evt || window.event; window.event ? e.cancelBubble = true : e.stopPropagation(); }
好了,今天就先写到这里了。。。。O(∩_∩)O~~~