JS事件:绑定事件方式、事件的冒泡和默认事件、鼠标事件、键盘事件、表单 事件、文档事件、图片事件、页面事件

一、事件的两种绑定方式

1、on事件绑定方式

document.onclick = function() {
console.log("文档点击");
}
// on事件只能绑定一个方法,重复绑定保留最后一次绑定的方法
// .onclick = function (){}
document.onclick = function() {
console.log("文档点击");
}
// 事件的移除
document.onclick = null;

2、非on事件绑定方式

document.addEventListener('click', function() {
console.log("点击1");
})
document.addEventListener('click', function() {
console.log("点击2");
})
// 非on事件可以同时绑定多个方法,被绑定的方法依次被执行
// addEventListener第三个参数(true|false)决定冒泡的方式
// addEventListener('事件',fn,冒泡方式)
function fn () {}
document.addEventListener('click', fn);
// 事件的移除
document.removeEventListener('click', fn);

二、事件参数event

  • 存放事件信息的回调参数

三、事件的冒泡与默认事件

  • 事件的冒泡:父子都具有点击事件,不处理的话,点击子级也会出发父级的点击事件
  • 处理冒泡:(ev是onclick传出来的数据,回调函数获取并处理)
方法一. ev.cancelBubble = True;
方法二. ev.stopprppagation()
<body id="body">
<div id="sup">
<div id="sub"></div>
</div>
</body> <script>
sub.onclick = function (ev) {
// 方式一:ev.stopPropagation();
ev.stopPropagation();
console.log("sub click");
}
sup.onclick = function (ev) {
// 方式二:ev.cancelBubble = true;
ev.cancelBubble = true;
console.log("sup click");
} </script>
  • 默认事件:取消默认的事件动作,如鼠标右键会弹出菜单
  • 取消默认事件:
方法一. return false()
方法二. ev.preventDefault()
<body id="body">
<div id="sup">
<div id="sub"></div>
</div>
</body> <script>
sub.oncontextmenu = function (ev) {
// 方式一:ev.preventDefault();
ev.preventDefault();
console.log("sub menu click");
}
sup.oncontextmenu = function (ev) {
console.log("sup menu click");
// 方式二:return false;
return false;
} </script>

四、鼠标事件

  • 鼠标事件
onclick:鼠标点击
ondblclick:鼠标双击
onmousedown:鼠标按下
onmousemove:鼠标移动
onmouseup:鼠标抬起
onmouseover:鼠标悬浮
onmouseout:鼠标移开
oncontextmenu:鼠标右键
  • 事件参数ev
ev.clientX:点击点X坐标
ev.clientY:点击点Y坐标
div.onmousemove = function (ev) {
// 鼠标在页面中的位置
console.log("x的坐标:", ev.clientX);
console.log("y的坐标:", ev.clientY);
console.log("移动");
}

五、键盘事件

1. 操作一般标签,键盘事件绑定给document
2. 表单标签(可以录入文本),键盘事件绑定给表单标签
  • 键盘事件
onkeydown:键盘按下
onkeyup:键盘抬起
  • 事件参数ev
ev.keyCode:按键编号,键盘上每个按键都有唯一的编号
ev.altKey:alt特殊按键
ev.ctrlKey:ctrl特殊按键
ev.shiftKey:shift特殊按键
// 案例,键盘控制上下左右移动
var div = document.querySelector('.div');
document.onkeydown = function (ev) {
// console.log(ev.keyCode);
switch(ev.keyCode) {
case 37:
console.log("左");
// offsetLeft 获取移动钱左端所在位置
div.style.left = div.offsetLeft - 3 + "px";
break;
case 38:
console.log("上");
// offsetTop 获取移动钱上端所在位置
div.style.top = div.offsetTop - 3 + "px";
break;
case 39:
console.log("右");
div.style.left = div.offsetLeft + 3 + "px";
break;
case 40:
console.log("下");
div.style.top = div.offsetTop + 3 + "px";
break;
}
}
<script type="text/javascript">
// 平滑的移动
var div = document.querySelector('.div'); // 能否向左|右|上|下运动
var l_able = false;
var t_able = false;
var r_able = false;
var b_able = false;
setInterval(function () {
// l_able为假,则后者短路,可以实现if的简写
l_able && (div.style.left = div.offsetLeft - 3 + 'px'); // 左
t_able && (div.style.top = div.offsetTop - 3 + 'px'); // 上
if (r_able == true) {
div.style.left = div.offsetLeft + 3 + 'px'; // 右
}
b_able && (div.style.top = div.offsetTop + 3 + 'px'); // 下 }, 16); document.onkeydown = function (ev) {
switch(ev.keyCode) {
case 37: l_able = true; break;
case 38: t_able = true; break;
case 39: r_able = true; break;
case 40: b_able = true; break;
}
} document.onkeyup = function (ev) {
console.log(ev);
switch(ev.keyCode) {
case 37: l_able = false; break;
case 38: t_able = false; break;
case 39: r_able = false; break;
case 40: b_able = false; break;
}
}
</script>

六、表单事件

onfocus:获取焦点
onblur:失去焦点
onselect:文本被选中
oninput:值改变
onchange:值改变,且需要在失去焦点后才能触发
onsubmit:表单默认提交事件,form表单专有的事件
	var form = document.querySelector('form');
var ipt = document.querySelector('input');
var btn = document.querySelector('button');
var div = document.querySelector('div'); ipt.onselect = function () {
console.log("文本被选中了");
}
// 值改变就触发
ipt.oninput = function () {
console.log("值在改变");
div.innerText = this.value;
}
// 键盘抬起触发
ipt.onkeyup = function () {
console.log("值在改变");
div.innerText = this.value;
} // 值改变,并且在失去焦点时触发
ipt.onchange = function () {
console.log("值在改变");
div.innerText = this.value;
}
// form的专有事件
form.onsubmit = function () {
console.log("提交");
return false; // 取消默认事件
}

七、文档事件

  • 文档事件由window调用
onload:页面加载成功
onbeforeunload:页面退出或刷新警告,需要设置回调函数返回值,返回值随意
<script type="text/javascript">
// 文档加载完毕,触发
window.onload = function () {
var div = document.querySelector('div');
console.log(div);
}
</script> <script type="text/javascript">
// 退出页面
window.onbeforeunload = function () {
return false;
}
</script>

八、图片事件

onerror:图片加载失败

九、页面事件

  • window来调用
onscroll:页面滚动
onresize:页面尺寸调整
window.scrollY:页面下滚距离
<script type="text/javascript">
window.onload = function () {
window.onscroll = function () {
console.log(window.scrollY);
}
</script>

最新文章

  1. 9、委托、事件、Lambda
  2. Log4net - 规则简介
  3. Intent
  4. SetForegroundWindow激活窗口
  5. Android布局6大类
  6. android Java BASE64编码和解码一:基础
  7. PHP+jQuery 注册模块的改进之三:使用 Smarty3
  8. POJ3624
  9. oracle 清除当前用户的回收站
  10. Eclipse 中打不开android sdk managerf
  11. python中的小技巧
  12. 在Eclipse中导入文件和文件夹
  13. brew命令
  14. iOS 数据库操作(使用FMDB)
  15. SSE图像算法优化系列十一:使用FFT变换实现图像卷积。
  16. Java 写三角形 空心三角形 菱形 空心菱形
  17. Nginx:Linux下安装Nginx与配置
  18. 异常:Instantiation of bean failed; nested exception is java.lang.NoSuchMethodError: com.google.common.base.Preconditions.che ckState(ZLjava/lang/String;I)V
  19. [DP][NOIP2013]花匠
  20. Spring 4 MVC example with Maven - [Source Code Download]

热门文章

  1. ceph-pg
  2. JAVA学习之面向对象
  3. Tomcat_shutdown
  4. 2019杭电多校第六场hdu6638 Snowy Smile(线段树+枚举)
  5. upc组队赛3 T-net【贪心】
  6. python学习笔记:网络请求——requests模块
  7. Config JAVA evironment for LoadRunner
  8. CSS 中的各种居中 (水平、垂直)
  9. Jsoup爬虫任务总结
  10. android中使用MediaRecoder录制声音