js事件处理-整理
<!--
作者: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事件处理-整理的更多相关文章
- 常用js方法整理common.js
项目中常用js方法整理成了common.js var h = {}; h.get = function (url, data, ok, error) { $.ajax({ url: url, data ...
- js事件处理 —— 详解
对于JS事件处理分为四部分: 1.html事件处理程序 直接添加到HTML结构中 解析:用html处理程序可以直接在button元素里直接调用,但是维护性不是很方便 <!DOCTYPE html ...
- 项目中常用js方法整理common.js
抽空把项目中常用js方法整理成了common.js,都是网上搜集而来的,大家一起分享吧. var h = {}; h.get = function (url, data, ok, error) { $ ...
- JS知识点整理(二)
前言 这是对平时的一些读书笔记和理解进行整理的第二部分,第一部分请前往:JS知识点整理(一).本文包含一些易混淆.遗漏的知识点,也会配上一些例子,也许不是很完整,也许还会有点杂,但也许会有你需要的,后 ...
- Vue.js事件处理
Vue.js事件处理 1.v-on指令 用法如下:使用v-on:指令指定其执行的具体内容或者方法名即可. <button v-on:click='num++'>giao</butto ...
- 常用js代码整理、收集
个人整理了一下个人常用到的一些js代码,以方便学习以及日后使用,或许有一些是个人之前从网上摘下来的,但是不记得是具体从哪里来的了,如果你看到有一段代码跟你的文章很相似甚至一样,请不要气愤,请告诉我,我 ...
- 工作中常用的JS函数整理分享(欢迎大家补充)
今年在渣X工作整理的常用JS函数 今年来了渣X工作,我所在这个部门分工很奇怪,CSS竟然有专门的人在搞,开发PHP的人员需要处理JS,以至于有时候开发起来不是那么得心应手,感觉把JS和CSS拆开就像是 ...
- 常用js方法整理(个人)
开头总要有点废话 今天想了下,还是分享下自己平时积累的一些实用性较高的js方法,供大家指点和评价.本想分篇介绍,发现有点画蛇添足.整理了下也没多少拿得出手的方法,自然有一些是网上看到的个人觉得很有实用 ...
- JS知识点整理(一)
前言 本文把平时的一些读书笔记和理解进行了整理归纳,包含一些易混淆.遗漏的知识点,也会配上一些例子,可能不是很完整,还会有点杂,但也许会有你需要的(目前先整理了一部分,笔记有点多,后续会持续更新). ...
随机推荐
- PyQt4单选框QCheckBox
PyQt4中的部件 部件是构建应用程序的基础元素.PyQt4工具包拥有大量的种类繁多的部件.比如:按钮,单选框,滑块,列表框等任何程序员在完成其工作时需要的部件. QCheckBox单选框 单选框具有 ...
- poj_2739 尺取法
题目大意 给定一个数字N,N可能由1个或多个连续的素数求和得到,比如41 = 2+3+5+7+11+13, 41 = 11+13+17, 41 = 41.求出对于N,所有可能的组合形式. 题目分析 先 ...
- SenchaTouch学习博客
魔狼在世: http://www.cnblogs.com/mlzs/
- Android Activity 半透明效果(Translucent)
本文转自:http://norety.javaeye.com/blog/648725 今天试着做activity半透明的效果,做出来之后才发现想复杂了!很简单的几句就可以实现,不多说了,贴代码! 1. ...
- mysql中or和in的效率问题
分三中情况进行测试,分别是:第一种情况:in和or所在列为主键的情形.第二种情况:in和or所在列创建有索引的情形.第二种情况:in和or所在列没有索引的情形.每种情况又采用不同的in和or的数量进行 ...
- 浙江工业大学校赛 XiaoWei的战斗力
XiaoWei的战斗力 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
- 沈阳网络赛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 ...
- MyBatis 的真正强大在于它的映射语句 如果有一个独立且完美的数据库映射模式,所有应用程序都可以使用它
mybatis – MyBatis 3 | Mapper XML 文件 http://www.mybatis.org/mybatis-3/zh/sqlmap-xml.html mybatis – My ...
- python操作redis详解
https://www.cnblogs.com/koka24/p/5841826.html
- 7.1 - CRM系统
一.简介 crm 客户关系管理软件 ( Customer Relationship Management ) ( 详细内容 ) stark组件(仿admin组件)( 详细内容 ) rbac组件(基于角 ...