开发者社区> 我要学编程> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

js事件

简介:
+关注继续查看

JS事件

一、事件的两种绑定方式 *

1、on事件绑定方式

document.onclick = function() {
    console.log("文档点击");
}
// on事件只能绑定一个方法,重复绑定保留最后一次绑定的方法
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)决定冒泡的方式
function fn () {}
document.addEventListener('click', fn);
// 事件的移除
document.removeEventListener('click', fn);

二、事件参数event *

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

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

  • 事件的冒泡:父子都具有点击事件,不处理的话,点击子级也会出发父级的点击事件
<body id="body">
       <div id="sup">
        <div id="sub"></div>
    </div>
</body>

<script>
sub.onclick = function (ev) {
    // 方式一
    ev.stopPropagation();
    console.log("sub click");
}
sup.onclick = function (ev) {
    // 方式二
    ev.cancelBubble = true;
    console.log("sup click");
}
body.onclick = function (ev) {
    console.log("body click");
}
</script>
  • 默认事件:取消默认的事件动作,如鼠标右键菜单
  • ev.preventDefault(); | return false;
<body id="body">
       <div id="sup">
        <div id="sub"></div>
    </div>
</body>

<script>
    //默认事件:鼠标右键oncontextmenu
    sub.oncontextmenu = function (ev) {
        ev.preventDefault();
        console.log("sub menu click");
    }

    //父级取消了默认事件,子级都被取消掉了
    body.oncontextmenu = function(ev){
        console.log("body menu click");
        return false;
    }
</script>

四、鼠标事件 *

  • 鼠标事件
onclick:鼠标点击
ondblclick:鼠标双击
onmousedown:鼠标按下
onmousemove:鼠标移动
onmouseup:鼠标抬起
onmouseover:鼠标悬浮 onmouseenter
onmouseout:鼠标移开 onmouseleave
oncontextmenu:鼠标右键
  • 事件参数ev
ev.clientX:点击点X坐标
ev.clientY:点击点Y坐标

五、键盘事件 *

  • 键盘事件
onkeydown:键盘按下
onkeyup:键盘抬起
// 绑定的对象: 对象自身不录入文本,绑给document,自身录入文本(表单标签),绑给自身
ev.keyCode
  • 事件参数ev
ev.keyCode:按键编号
ev.altKey:alt特殊按键
ev.ctrlKey:ctrl特殊按键
ev.shiftKey:shift特殊按键
  • 键盘控制平滑运动
<div class="div"></div>
<script>
    var div =document.querySelector('.div');

    var r_able =false;
    var l_able =false;
    var t_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){
            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 39: r_able=true; break;
            case 37: l_able=true; break;
            case 38: t_able=true; break;
            case 40: b_able=true; break;
        }
    }
    document.onkeyup = function (ev) {
        switch(ev.keyCode){
            case 39: r_able=false; break;
            case 37: l_able=false; break;
            case 38: t_able=false; break;
            case 40: b_able=false; break;
        }
    }
</script>

六、表单事件 *

onfocus:获取焦点
onblur:失去焦点
onselect:文本被选中
oninput:值改变
onchange:值改变,且需要在失去焦点后才能触发
onsubmit:表单默认提交事件
<form action="">
    <input type="text" name="usr">
    <button type="submit">提交</button>
</form>
<script>
    var form = document.querySelector('form');
    var ipt=document.querySelector('input');
    var btn =document.querySelector('button');

    ipt.onselect = function () {
        console.log("文本被选中了");
    }
    //值改变就触发
    ipt.oninput=function(){
        console.log("值在改变");
    }
    //键盘抬起就触发
    ipt.onkeyup =function () {
        console.log("值在改变");
    }

    //丢失焦点触发
    ipt.change =function () {
        console.log("值在改变");
    }

    //form的专有事件
    form.onsubmit = function () {
        console.log("提交");
        return false;//取消默认事件
    }
</script>

七、文档事件 *

  • 文档事件由window调用
onload:页面加载成功
onbeforeunload:页面退出或刷新警告,需要设置回调函数返回值,返回值随意

八、图片事件 *

onerror:图片加载失败

九、页面事件 *

onscroll:页面滚动
onresize:页面尺寸调整
window.scrollY:页面下滚距离

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
【JavaScript框架封装】实现一个类似于JQuery的动画框架的封装
版权声明:本文为博主原创文章,未经博主允许不得转载。更多学习资料请访问我爱科技论坛:www.52tech.tech https://blog.csdn.net/m0_37981569/article/details/81123854 ...
855 0
【JavaScript框架封装】实现一个类似于JQuery的DOM框架的封装
版权声明:本文为博主原创文章,未经博主允许不得转载。更多学习资料请访问我爱科技论坛:www.52tech.tech https://blog.csdn.net/m0_37981569/article/details/81123835 ...
697 0
【JavaScript框架封装】实现一个类似于JQuery的内容框架的封装
版权声明:本文为博主原创文章,未经博主允许不得转载。更多学习资料请访问我爱科技论坛:www.52tech.tech https://blog.csdn.net/m0_37981569/article/details/81123820 ...
713 0
【JavaScript框架封装】实现一个类似于JQuery的属性框架的封装
版权声明:本文为博主原创文章,未经博主允许不得转载。更多学习资料请访问我爱科技论坛:www.52tech.tech https://blog.csdn.net/m0_37981569/article/details/81123810 ...
611 0
【JavaScript框架封装】实现一个类似于JQuery的选择框架的封装
版权声明:本文为博主原创文章,未经博主允许不得转载。更多学习资料请访问我爱科技论坛:www.52tech.tech https://blog.csdn.net/m0_37981569/article/details/81123799 ...
711 0
【JavaScript框架封装】实现一个类似于JQuery的CSS样式框架的封装
版权声明:本文为博主原创文章,未经博主允许不得转载。更多学习资料请访问我爱科技论坛:www.52tech.tech https://blog.csdn.net/m0_37981569/article/details/81123779 ...
755 0
【JavaScript框架封装】实现一个类似于JQuery的事件框架的封装
版权声明:本文为博主原创文章,未经博主允许不得转载。更多学习资料请访问我爱科技论坛:www.52tech.tech https://blog.csdn.net/m0_37981569/article/details/81123753 ...
664 0
JavaScript自定义事件
标题JavaScript自定义事件 最近遇到一个基于jQuery项目,项目中的功能节点页面都是通过iframe实现,但是各个iframe之间有时需要相互通信,互相相应一些事件,为了更愉快的编码所以想到了自定义事件,还别说用起来竟然有点像vue的组件通信 top.
580 0
+关注
我要学编程
热爱学习,愿意接收新事物,有志称为一个互联网大佬
文章
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
Python第五讲——关于爬虫如何做js逆向的思路
立即下载
JS 语言在引擎级别的执行过程
立即下载