<!--

作者:gentiana@163.com

时间:2016-3-10

描述:js事件处理

-->

<!DOCTYPE html>

<html>

<head>

<meta
charset="UTF-8">

<title>js事件处理</title>

</head>

<body>

<form
action="http://www.baidu.com"
method="post"
>

<button
id="btn">按钮123</button>

</form>

<script>

 

//添加事件

var addEvent =
function(
obj, type, fn )
{

if
(obj.addEventListener){

obj.addEventListener( type, fn,
false
);

}else
if
(obj.attachEvent)
{

obj["e"+type+fn]
= fn;

obj.attachEvent(
"on"+type,
function()
{

obj["e"+type+fn].call(obj, window.event);

}
);

}

};

 

var test =
function(e){

alert('Listener');

stopEvent(e);

}

var test2 =
function(){

alert('remove');

}

var btn = document.getElementById('btn');

addEvent(btn,
'click', test);

 

 

//移除事件

 

var removeEvent =
function(
obj, type, fn )
{

if
(obj.removeEventListener){

obj.removeEventListener( type, fn,
false
);

}

 

else
if
(obj.detachEvent)
{

obj.detachEvent(
"on"
+type, obj["e"+type+fn]
);

obj["e"+type+fn]
= null;

}

};

 

 

 

 

//阻止事件(包括冒泡和默认行为)

 

var stopEvent =
function(e){

e = e || window.event;

if(e.preventDefault)
{

e.preventDefault();

e.stopPropagation();

}else{

e.returnValue =
false;

e.cancelBubble =
true;

}

};

 

//仅阻止事件冒泡

 

var stopPropagation =
function(e)
{

e = e || window.event;

if
(e.preventDefault)
{

e.cancelBubble =
true;

}
else
{

e.stopPropagation();

}

};

 

 

//仅阻止浏览器默认行为

 

var preventDefault =
function(e)
{

e = e || window.event;

if(e.preventDefault)
{

e.preventDefault();

}else{

e.returnValue =
false;

}

}

 

//取得事件源对象

 

var getEventTarget =
function(e){

e = e || window.event;

var target = event.srcElement ? event.srcElement : event.target;

return target;

};

 

 

</script>

</body>

</html>

js事件处理-整理的更多相关文章

  1. 常用js方法整理common.js

    项目中常用js方法整理成了common.js var h = {}; h.get = function (url, data, ok, error) { $.ajax({ url: url, data ...

  2. js事件处理 —— 详解

    对于JS事件处理分为四部分: 1.html事件处理程序 直接添加到HTML结构中 解析:用html处理程序可以直接在button元素里直接调用,但是维护性不是很方便 <!DOCTYPE html ...

  3. 项目中常用js方法整理common.js

    抽空把项目中常用js方法整理成了common.js,都是网上搜集而来的,大家一起分享吧. var h = {}; h.get = function (url, data, ok, error) { $ ...

  4. JS知识点整理(二)

    前言 这是对平时的一些读书笔记和理解进行整理的第二部分,第一部分请前往:JS知识点整理(一).本文包含一些易混淆.遗漏的知识点,也会配上一些例子,也许不是很完整,也许还会有点杂,但也许会有你需要的,后 ...

  5. Vue.js事件处理

    Vue.js事件处理 1.v-on指令 用法如下:使用v-on:指令指定其执行的具体内容或者方法名即可. <button v-on:click='num++'>giao</butto ...

  6. 常用js代码整理、收集

    个人整理了一下个人常用到的一些js代码,以方便学习以及日后使用,或许有一些是个人之前从网上摘下来的,但是不记得是具体从哪里来的了,如果你看到有一段代码跟你的文章很相似甚至一样,请不要气愤,请告诉我,我 ...

  7. 工作中常用的JS函数整理分享(欢迎大家补充)

    今年在渣X工作整理的常用JS函数 今年来了渣X工作,我所在这个部门分工很奇怪,CSS竟然有专门的人在搞,开发PHP的人员需要处理JS,以至于有时候开发起来不是那么得心应手,感觉把JS和CSS拆开就像是 ...

  8. 常用js方法整理(个人)

    开头总要有点废话 今天想了下,还是分享下自己平时积累的一些实用性较高的js方法,供大家指点和评价.本想分篇介绍,发现有点画蛇添足.整理了下也没多少拿得出手的方法,自然有一些是网上看到的个人觉得很有实用 ...

  9. JS知识点整理(一)

    前言 本文把平时的一些读书笔记和理解进行了整理归纳,包含一些易混淆.遗漏的知识点,也会配上一些例子,可能不是很完整,还会有点杂,但也许会有你需要的(目前先整理了一部分,笔记有点多,后续会持续更新). ...

随机推荐

  1. PyQt4单选框QCheckBox

    PyQt4中的部件 部件是构建应用程序的基础元素.PyQt4工具包拥有大量的种类繁多的部件.比如:按钮,单选框,滑块,列表框等任何程序员在完成其工作时需要的部件. QCheckBox单选框 单选框具有 ...

  2. poj_2739 尺取法

    题目大意 给定一个数字N,N可能由1个或多个连续的素数求和得到,比如41 = 2+3+5+7+11+13, 41 = 11+13+17, 41 = 41.求出对于N,所有可能的组合形式. 题目分析 先 ...

  3. SenchaTouch学习博客

    魔狼在世: http://www.cnblogs.com/mlzs/

  4. Android Activity 半透明效果(Translucent)

    本文转自:http://norety.javaeye.com/blog/648725 今天试着做activity半透明的效果,做出来之后才发现想复杂了!很简单的几句就可以实现,不多说了,贴代码! 1. ...

  5. mysql中or和in的效率问题

    分三中情况进行测试,分别是:第一种情况:in和or所在列为主键的情形.第二种情况:in和or所在列创建有索引的情形.第二种情况:in和or所在列没有索引的情形.每种情况又采用不同的in和or的数量进行 ...

  6. 浙江工业大学校赛 XiaoWei的战斗力

    XiaoWei的战斗力 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Tota ...

  7. 沈阳网络赛D-Made In Heaven【k短路】【模板】

    One day in the jail, F·F invites Jolyne Kujo (JOJO in brief) to play tennis with her. However, Pucci ...

  8. MyBatis 的真正强大在于它的映射语句 如果有一个独立且完美的数据库映射模式,所有应用程序都可以使用它

    mybatis – MyBatis 3 | Mapper XML 文件 http://www.mybatis.org/mybatis-3/zh/sqlmap-xml.html mybatis – My ...

  9. python操作redis详解

    https://www.cnblogs.com/koka24/p/5841826.html

  10. 7.1 - CRM系统

    一.简介 crm 客户关系管理软件 ( Customer Relationship Management ) ( 详细内容 ) stark组件(仿admin组件)( 详细内容 ) rbac组件(基于角 ...