day47—JavaScript事件基础应用
2024-10-07 10:17:51
转行学开发,代码100天——2018-05-02
1.事件对象
JavaScript中事件对象通常用定义变量ev或event表示。为了兼顾浏览器兼容问题,定义事件对象为
var oEvent = ev||event;
2.鼠标事件
鼠标事件通常有获取鼠标点击位置clientX;clientY
鼠标移动事件:onmousemove;
鼠标点击事件:onmousedown;
鼠标抬起事件:onmouseup;
如设置一个鼠标跟随程序:
物体跟随鼠标移动。
<!DOCTYPE html>
<html>
<head>
<title>javascript 鼠标事件</title>
<style type="text/css">
#div1{width: 100px;height: 100px;background: red;position: absolute;}
</style>
<script type="text/javascript">
document.onmousemove = function(ev)
{
var oEvent = ev||event;
var oDiv = document.getElementById("div1");
var scrollTop = document.documentElement.scrollTop||document.body.scrollTop;
oDiv.style.left = oEvent.clientX+"px";
oDiv.style.top = oEvent.clientY+scrollTop+"px";
}
</script>
</head>
<body style="height: 2000px;">
<div id="div1"></div>
</body>
</html>
注意:在使用clientX和clientY时一定要结合scrollLeft和scrollTop一起使用。
在这里可以试着去封装一个获取鼠标坐标的函数。
//鼠标坐标值获取
function getPos(ev)
{
var scrollTop = document.documentElement.scrollTop||document.body.scrollTop;
var scrollLeft = document.documentElement.scrollLeft || document.body.scrollLeft;
return {
x:ev.clientX+scrollLeft,
y:ev.clientY+scrollTop
};
}
3.事件冒泡
事件冒泡通常会影响网页运行效果,一般需要设置阻止事件冒泡的发生。
如一个模仿select按钮的效果,通过点击按钮,弹出内容框;点击视图中其他区域,内容框消失。
其代码如下:
<!DOCTYPE html>
<html>
<head>
<title>仿select效果</title>
<style type="text/css">
#div1{width: 200px; height: 200px;background: #ccc;display: none;}
</style>
<script type="text/javascript">
window.onload = function()
{
var btn1 = document.getElementById("btn1");
var div1 = document.getElementById("div1"); btn1.onclick = function(ev)
{
var oEvent = ev||event;
div1.style.display = "block";
alert("按钮被点击了");
oEvent.cancelBubble = true; }
document.onclick = function()
{
div1.style.display = "none";
alert("document被点击了");
}
}
</script>
</head>
<body> <input id="btn1" type="button" value="显示" >
<div id="div1"></div>
</body>
</html>
可以看到,代码中对按钮添加了阻止冒泡的功能,oEvent.cancelBubble = true;
否则在点击显示按钮后,先后弹出
"按钮被点击了"
"document被点击了"
但实际上内容灰色框并不会显示。 所以在事件的使用中至少需要注意以下问题: 1)兼容性问题
2)事件冒泡问题
最新文章
- screen
- php各种编码集详解和以及在什么情况下进行使用
- 注解:【无连接表的】Hibernate单向N->;1关联
- 叠罗汉III之推箱子
- js中eval函数
- android——混淆打包
- Delphi用ADOquery主从表例子(转总结)
- map map
- 【Beta】 第五次Daily Scrum Meeting
- onCreate和onStart谁的开销大?
- 安装selenium
- Javascript高级编程学习笔记(65)—— 事件(9)复合事件
- 使用WinIo32绕过密码控件实现自动登录
- 扫描系统进程和获取某进程的PID
- shiro自定义realm认证(五)
- 温馨小程序前端布局Flex
- Spring学习四
- Spring Cloud搭建手册(2)——Spring Cloud Config
- [py]函数中yield多次返回,延迟计算特性-杨辉三角
- List、Set、Map