Javascript知识——事件

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

鼠标事件:页面所有元素都可触发

  • 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>
  • ondblclick双击事件
input.ondblclick = function () {
alert(this.value);
};
  • mousedown:当用户按下了鼠标还未弹起时触发
input.onmousedown = function () {
alert(this.value);
};
  • mouseup:当用户释放鼠标按钮时触发
input.onmouseup = function () {
alert(this.value);
};
  • mouseover:当鼠标移到某个元素上方时触发
input.onmouseover = function () {
alert(this.value);
};
  • mouseout:当鼠标移出某个元素上方时触发
input.onmouseout = function () {
alert(this.value);
};
  • mousemove:当鼠标指针在元素上移动时触发
input.onmousemove = function () {
alert(this.value);
};

键盘事件:

keydown:当用户按下键盘上任意键触发,如果按住不放,会重复触发

keypress:当用户按下键盘上的字符键触发,如果按住不放,会重复触发

keyup:当用户释放键盘上的键触发

HTML事件:

  • load: 当页面完全加载后在 window 上面触发, 或当框架集加载完毕后在框架集上触发
window.onload = function () {
alert(‘Hello World’);
};
  • unload:当页面完全卸载后在 window 上面触发,或当框架集卸载后在框架集上触发
window.onunload = function () {
alert(‘Hello World‘);
};
  • select:当用户选择文本框(input 或 textarea)中的一个或多个字符触发
input.onselect = function () {
alert(‘Hello World‘);
};
  • change:当文本框(input 或 textarea)内容改变且失去焦点后触发
input.onchange = function () {
alert(‘Hello World‘);
};
  • focus:当页面或者元素获得焦点时在 window 及相关元素上面触发
input.onfocus = function () {

alert(‘Hello World‘);

};
  • blur:当页面或元素失去焦点时在 window 及相关元素上触发
input.onblur = function () {

alert(‘Hello World‘);

};
  • submit:当用户点击提交按钮在<form>元素上触发
form.onsubmit = function () {

alert(‘Hello World‘);

}
  • reset:当用户点击重置按钮在<form>元素上触发
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~~~

时间: 2024-08-06 16:06:24

Javascript知识——事件的相关文章

《jQuery风暴》第2章 必须知道的JavaScript知识

第2章 必须知道的JavaScript知识 JavaScript是jQuery应用的基础,掌握JavaScript这门语言是使用jQuery的基础条件.本章不会全面细致的讲解JavaScript的全部, 而是讲解其精髓,这些知识可以提升大家的JavaScript内功.切忌,要修炼上乘的武功,必须要有深厚的内功基础,否则只可学到其招式而发挥不了功力.JavaScript实际上包括三部分: w   ECMAScript 描述了该语言的语法和基本对象. w   DOM 描述了处理网页内容的方法和接口.

JavaScript的事件监听、捕获和冒泡

在前端开发中,我们经常需要对某些事件进行监听.这样只要在指定的元素上触发了该事件,就会执行一个回调函数来进行相关的操作. 而JavaScript中事件监听的方法总共有三种,分别如下: element.addEventListener(type, listener[, useCapture]); //IE6~8不支持 element.attachEvent('on' + type, listener)     //支持IE6~10,IE11不支持 element['on' + type] = fu

JavaScript中事件绑定的方法总结

最近收集了一些关于JavaScript绑定事件的方法,汇总了一下,不全面,但是,希望便于以后自己查看. JavaScript中绑定事件的方法主要有三种: 1 在DOM元素中直接绑定 2 JavaScript代码中直接绑定 3 绑定事件监听函数 一.在DOM元素中直接绑定 也就是直接在html标签中通过 onXXX=“” 来绑定.举个例子: <input type="button" value="点我呦" onclick="alert("he

javaScript 删除事件 弹出确认 取消对话框

1 javaScript 删除事件 弹出确认 取消对话框 2 1. 3 4 <a href="javascript:if(confirm('确实要删除?'))location='http://www.baidu.com'">删除</a> 5 6 2. 7 8 <script language="JavaScript"> 9 function delete_confirm(e) 10 { 11 if (event.srcElemen

JavaScript onkeydown事件入门实例(键盘某个按键被按下)

JavaScript onkeydown 事件 用户按下一个键盘按键时会触发 onkeydown 事件.与 onkeypress事件不同的是,onkeydown 事件是响应任意键按下的处理(包括功能键),onkeypress 事件只响应字符键按下后的处理. 提示 Internet Explorer/Chrome 浏览器使用 event.keyCode 取回被按下的字符,而 Netscape/Firefox/Opera 等浏览器使用 event.which. onkeydown 获取用户按下的键

JavaScript 阻止事件冒泡的实现方法

JavaScript 阻止事件冒泡,无使用其它插件来辅助,原生JS代码,考虑到浏览器的兼容性问题,这里对IE/火狐.Operating以及Chrome都有针对性的判断,代码如下: function cancelBubble(evt) { // 阻止事件冒泡 if (window.event) { // Chrome,IE6,Opera window.event.cancelBubble = true; } else { // FireFox 3 evt.stopPropagation(); }

JavaScript知识体系

JavaScript知识版图 Language ECMAScript Browser BOM DOM Other Transmition Ajax.JSON Server-side Node JavaScript纵向生态 应用层 交互逻辑 组件层 定制组件 通用组件 如Datepicker 框架层 jQuery.Angular.React…… 核心层 原生js和底层API 分类依据:什么是编程语言?编程语言就是用于操纵计算机干活的指令.计算机能干什么活?计算机只会干一件事,那就是处理数据.因此编

JavaScript 自定义事件

Javascript事件模型系列(四)我所理解的javascript自定义事件 漫谈js自定义事件.DOM/伪DOM自定义事件

[转]javascript指定事件处理程序包括三种方式:

javascript指定事件处理程序包括三种方式: (1):DOM0级事件处理程序 如: 代码如下: var btn=document.getElementById("mybtn"); //取得该按钮的引用 btn.onclick=function(){ alert('clicked'); alert(this.id); // mybtn 以这种方式添加的事件处理程序会在事件流的冒泡阶段被处理. 删除DOM0级方法指定的事件处理程序: btn.onclick=null; // 删除事件