zoukankan      html  css  js  c++  java
  • DAY59-前端入门-javascript(六)JS事件

    js事件

    一、事件

    ​ 发生的某一件事。触发特定的条件,完成某一项功能

    二、事件的两种绑定方式

    ​1、on事件绑定方式

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

    2、非on事件绑定方式

    // addEventListener('事件名', 回调函数, 冒泡方式(true|false))
    document.addEventListener('click', function() {
         console.log("点击1");
    })
    document.addEventListener('click', function() {
         console.log("点击2");
    })
    // 非on事件可以同时绑定多个方法,被绑定的方法依次被执行
    
    // 事件的移除
    document.removeEventListener('click', fn);
    
    // 注:绑定与移除需要指向同一个方法(地址)
    

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

    冒泡: 父子级拥有同一的事件,在子级区域触发子级事件,父级也能捕获并响应

    event:存放事件信息的回调参数

    <body>
    	<div class="sup">
    		<div class="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) {
    	// 事件的兼容
    	// ev = ev | event;
    	// 点击传过来的是 MouseEvent,存储着鼠标触发事件的一系列信息
    	console.log(ev);
    	console.log("body click");
    }
    </script>
    

    默认事件:取消默认的事件动作,如鼠标右键菜单

    <script>
    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:鼠标悬浮
    onmouseout:鼠标移开
    oncontextmenu:鼠标右键
    
    • 事件参数ev
    ev.clientX:点击点X坐标
    ev.clientY:点击点Y坐标
    

    五、键盘事件 *******

    • 键盘事件
    onkeydown:键盘按下
    onkeyup:键盘抬起
    
    • 事件参数ev
    ev.keyCode:按键编号
    ev.altKey:alt特殊按键
    ev.ctrlKey:ctrl特殊按键
    ev.shiftKey:shift特殊按键
    

    六、表单事件 *******

    onfocus:获取焦点
    onblur:失去焦点
    onselect:文本被选中
    oninput:值改变
    onchange:值改变,且需要在失去焦点后才能触发
    onsubmit:表单默认提交事件
    

    七、文档事件 *

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

    八、图片事件 *

    onerror:图片加载失败
    

    九、页面事件 *********

    onscroll:页面滚动
    onresize:页面尺寸调整
    
    window.scrollY:页面下滚距离
    
  • 相关阅读:
    开源项目之Android Afinal框架
    DateTimePicker——开源的Android日历类库
    Android 教你打造炫酷的ViewPagerIndicator
    Android UI-仿微信底部导航栏布局
    Android 下拉刷新框架实现
    Android-设置PullToRefresh下拉刷新样式
    Android-PullToRefresh下拉刷新库基本用法
    android 在使用ViewAnimationUtils.createCircularReveal()无法兼容低版本的情况下,另行实现圆形...
    Android5.0新特性——兼容性(support)
    求訪问啊啊啊啊
  • 原文地址:https://www.cnblogs.com/xvchengqi/p/9812508.html
Copyright © 2011-2022 走看看