AddEventListener()之中有三个参数,分别是(1)事件的名称(注:不要加on,例:click才是点击事件的名称)(2)需要执行的function(){} (3)布尔类型(false表示的是事件冒泡开启,true表示的是事件捕获开启)

EventTarget.prototype.addEventListener = function(type,listener,useCapture) {};
/**
@param {string} type
@param {EventListener|Function} listener
@param {boolean} [useCapture = false]
*/

封装添加事件的兼容性:

function addEventListener(element, type, listener) {
//能力检测
if(element.addEventListener) { //谷歌、火狐支持
element.addEventListener(type, listener, false);
}else if(element.attachEvent) { //ie浏览器
element.attachEvent("on" + type, listener);
}else{ // element.onclick=function(){}
element["on" + type] = listener;
}
}

封装移出事件的兼容性:

function removeEventListener(element,type,listener){
if(element.removeEventListener){
element.removeEventListener(type,listener,false);//谷歌火狐之中移除事件的方式
}else if(element.detachEvent){
element.detachEvent("on"+type,listener);//ie中移除事件的方式
}else{
element["on"+type]=null;//element.onclick=function(){}移除事件的方式,此处为何不能写成element.+”on”+type的形式,因为type是一个变量,对象的属性是变量时只能写在[]之中。
}
}

事件的添加与移除

添加:

<input type="button" value="按钮" id="btn"/>
<script>
var btn=document.getElementById("btn");
function test(){
alert("233");
}
//使用addEventListener添加一个点击事件
btn.addEventListener("click",test,false);
</script>

添加并移除:

<script>
var btn=document.getElementById("btn");
// //移除事件:当test命名函数被调用三次之后,移除点击事件
var num=0;
function test(){
num++;
alert("233");
if(num==3){
btn.removeEventListener("click",test,false);
} }
btn.addEventListener("click",test,false);
</script>

补充:我们在注册事件的时候需要考虑到注册事件的性能问题:

举个例子:给下面每一个li注册一个点击事件:

<ul id=”ul”>

<li>123</li>

<li>234</li>

<li>456</li>

<li>567</li>

</ul>

var ul = document.getElementById("ul");
//第一种方式
for(var i = 0, length = ul.children.length; i < length; i++) {
var li = ul.children[i]; li.onclick = function(){//此处可以看出每次都要注册运行一个匿名函数
console.log(this.innerText); };
} //第二种方式
for(var i = 0, length = ul.children.length; i < length; i++) {
var li = ul.children[i]; li.onclick = test; //而运用命名函数的方式则能大大提高程序的运行 //效率
} function test() {
console.log(this.innerText);
}

事件冒泡:

---事件委托(好处):举个例子吧我们现在的要求还是给每个li注册一个点击事件,此时我们可能会想到要给每一个li遍历注册事件,但是我们还有一种更加简单的方法那就是通过事件冒泡的方式委托给它的ul标签,对它进行事件注册

<ul id=”ul”>

<li>123</li>

<li>234</li>

<li>456</li>

<li>567</li>

</ul>

 var ul = document.getElementById("ul");
ul.addEventListener("click", function (e) {
alert(e.target.innerText);//e.target表示的是当前触//发事件的元素
}, false);

当然有好处便有坏处,举个例子我们在页面之中需要通过一个a标签来点击弹出一个窗口,假设a标签的id是link,窗口盒子的的id为box,  $$(“”)表示获取页面元素的id

$$(“link”).onclick=function(e){

$$(“box”).style.display=”block”;

e.stopPropagation();

}

这样点击a标签之后,盒子就显示出来了,但是我们还需要在单击页面空白之处隐藏盒子。因此就有了

Document.onclick=function(){

$$(“box”).style.display=”none”;}

那么问题就来了:我们会发现第一段之中的显示盒子代码不起效果,为什么呢?原因就在于事件冒泡,a标签处于document之中,第二段代码让盒子不显示,覆盖了a标签显示功能的执行。解决办法就是在第一段代码之中加入e.stopPropagation();以阻止事件冒泡

事件捕获:在文章开头我们讲到AddEventListener()之中有三个参数,其中最后一个参数是布尔类型的true/false.

在这里代表事件捕获的就是true.它与事件冒泡的顺序正好相反,若是发生盒子嵌套的话冒泡是由内而外显示,捕获是由外向内显示元素。

e.target的相关属性:

Box3是蓝色盒子,box2是绿色盒子,box1是红色盒子

上图console之中显示的为单机box3盒子时所触发的。

var elements=[box1,box2,box3];
for(var i= 0,length=elements.length;i<length;i++){
var element=elements[i];
// element.addEventListener("click",test,false);
element.addEventListener("mousedown",test,false);
}
function test(e){
e=e||window.event;
console.log("target:"+e.target.id);//target始终是点击的元素
console.log("currentTarget:"+ e.currentTarget.id);//currentTarget是冒泡的的元素
console.log("this:"+this.id);//与currentTarget保持一样
}
//除了在冒泡事件中,trget与currentTarget显示的内容是一样的。

正则表达式:

一、webstorm中按“ctrl+F”键打开,勾选Regex(正则表达式),match case(匹配大小写)

按“ctrl+R” 替换

//正则表达式的作用

1.匹配

2.获取

3.替换

//

二、常用的正则表达式规则

//2.1 元字符

//.   匹配任何单个字符,除了换行

//\d  数字   \D 非数字

//\w  数字 字母 下划线   \W 非

//\s  空白   \S 非空白

//\n  换行

//\t  制表符

//2.2  范围-- 匹配的是一个字符  ABCD

// [0-9]  [0123]  [a-z]  [A-Z]  匹配的是一个字符

//2.3  | 或者   \w|\d

//2.4  量词  -只修饰一个字符

//a+  1个或多个a

//a?  1个或0个a

//a*  0个或多个a

//var str = "aabbccddeeff";

//var regRex = /aa*b/;

//console.log(regRex.test(str));

//2.4  量词  -只修饰一个字符

//a{x}  x个n

//a{x,} 至少x个a

//a{x,y}  x-y个a

//2.5 开始结束

//^a  以a开始

//a$  以a结束

//2.6 () 看成一个整体

//2.7 匹配汉字

// [\u4e00-\u9fa5]

//    var str = "中华人民共和国";

//    var regRex = /[\u4e00-\u9fa5]{7}/;

//    console.log(regRex.test(str));

//2.8 参数

//i  忽略大小写

//g  全局匹配

在javascript之中创建正则表达式对象的两种写法:

下面这段代码也是利用正则表达式进行字符串的匹配判断:

输出的内容为true/false

<script>
// 第一种写法
// var regularExpression=new RegExp("\\d+");
// var str="abc";
// console.log(regularExpression.test(str));
//第二种写法
var regularExpression=/a?/;
var str="abc";
console.log(regularExpression.test(str));
</script>

在javascript之中正则表达式的提取:

举个例子:

var str="张三: 1000,李四:5000,王五:8000。";
var reg=/\d+/g;
var arr=str.match(reg);
console.log(arr);

将提取到的数字转换成数组的形式输出,/  /g====g表示的是global全局。

match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。

该方法类似 indexOf() 和 lastIndexOf(),但是它返回指定的值,而不是字符串的位置。

stringObject.match(searchvalue)

stringObject.match(regexp)

参数

描述

searchvalue

必需。规定要检索的字符串值。

regexp

必需。规定要匹配的模式的 RegExp 对象。如果该参数不是 RegExp 对象,则需要首先把它传递给 RegExp 构造函数,将其转换为 RegExp 对象。

<

js-事件、正则表达式的更多相关文章

  1. DIV+CSS+JS基础+正则表达式

    ...............HTML系列....................        DIV元素是用来为HTML文档内大块(block-level)的内容提供结构和背景的元素.DIV的起始 ...

  2. js常用正则表达式2

    字符 含意 \ 做为转意,即通常在"\"后面的字符不按原来意义解释,如/b/匹配字符"b",当b前面加了反斜杆后/\b/,转意为匹配一个单词的边界. -或- 对 ...

  3. JS常用正则表达式备忘录

    摘要: 玩转正则表达式. 原文:JS常用正则表达式备忘录 作者:前端小智 Fundebug经授权转载,版权归原作者所有. 正则表达式或"regex"用于匹配字符串的各个部分 下面是 ...

  4. Js与正则表达式

    原本接着上面的章节,这一章节应该是写 Jquery事件的,由工作需要,暂时横插一篇正则表达式的学习,这里是边学边记录,错误之处,希望指正,提拔一二,不甚感激! 此章节有 1.1 正则表达式的定义 1. ...

  5. js常用正则表达式,滚蛋吧!你们测试组bug,让你挑

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  6. JS 之正则表达式

    字符 含意 \ 做为转意,即通常在"\"后面的字符不按原来意义解释,如/b/匹配字符"b",当b前面加了反斜杆后/\b/,转意为匹配一个单词的边界. -或- 对 ...

  7. dynamic-css 动态 CSS 库,使得你可以借助 MVVM 模式动态生成和更新 css,从 js 事件和 css 选择器的苦海中脱离出来

    dynamic-css 使得你可以借助 MVVM 模式动态生成和更新 css,从而将本插件到来之前,打散.嵌套在 js 中的修改样式的代码剥离出来.比如你要做元素跟随鼠标移动,或者根据滚动条位置的变化 ...

  8. 什么是JS事件冒泡?

    什么是JS事件冒泡?: 在一个对象上触发某类事件(比如单击onclick事件),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事件处理 程序或者事件返回true,那么 ...

  9. js事件技巧方法整合

    window.resizeTo(800,600); //js设置浏览器窗口尺寸 window.open (function(){ resizeTo(640,480);//设置浏览器窗口尺寸 moveT ...

  10. js事件浅析

    js中关于DOM的操作很多,因此js事件机制也就尤为重要. 事件绑定形式: 一. 内联形式 耦合度高,不利于维护 <button onclick="alert('你点击了这个按钮'); ...

随机推荐

  1. python装饰器示例

    https://wiki.python.org/moin/PythonDecoratorLibrary#Property_Definition

  2. 数据库 MySql(二)

    MySQL(二) 1.外键及连表 外键 一个特殊的索引,只能是指定内容 CREATE TABLE part1 ( nid INT NOT NULL auto_increment PRIMARY KEY ...

  3. C预处理和C库

    #include <stdio.h> #define MAN(x) "n"##x int main(void) { printf("%s",MAN( ...

  4. No.5__C#

    One month 今天是个有纪念意义的日子,2015-4-23.今天是实习的第一个月,算是成就达成吧.虽然,除去了周末六日和清明什么的,只剩下20多天了,但是,还是好开心 啊,毕竟是第一次参加工作, ...

  5. linux下的磁盘和文件系统管理

    一.硬盘分区知识 1.分区类型 硬盘分区一共有3种:主分区.扩展分区和逻辑分区.扩展分区只不过是逻辑分区的“容器”,实际上只有主分区和逻辑分区进行数据存储.在一块硬盘上最多只能有4个主分区,可以另外建 ...

  6. 在Linux下给mysql创建用户并分配权限及问题解决方案

    在linux下安装mysql请参考在linux系统中安装mysql服务器详细步骤 1.新建用户 //登录MYSQL @>mysql -u root -p @>密码 //创建用户 mysql ...

  7. canvas画随机闪烁的星星

    canvas画一颗星星: 规则的星星有内切圆和外切圆,每两个点之间的角度是固定的,因此可得到星星的每个点的坐标,画出星星. function drawStars(x,y,radius1,radius2 ...

  8. ps 使用说明

    ps基本介绍 linux 版本 centos 1511  x64 汇报当前所有进程的快照.report a snapshot of the current processes. 能够显示F, S, U ...

  9. MySQL的错误:No query specified

    在做MySQL主从同步的时候通过: mysql> show slave status\G; *************************** 1. row **************** ...

  10. [转载] 3. JebAPI 之 jeb.api.ast

    本文转载自: https://www.zybuluo.com/oro-oro/note/143651 0. 序 Jeb 本身是支持变量重命名的,所以,混淆了的变量名.类名可以修改. 实际上,它还可以做 ...