Js-事件

一.事件的两种绑定方式

// on
绑定
div.onclick = function(){}
解绑
div.onclick=null

// 非on
var fn = function(){}
绑定
div.addEventListener('click', fn);
解绑
div.remove
EventListener('click', fn);

code:

<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <title>事件的两种绑定方式</title>
</head>
<body>
    <div class="div">12345</div>
</body>
<script type="text/javascript">
    var div = document.querySelector('.div');
    // on事件
    div.onclick = function () {
        console.log("点击1");
    }
    div.onclick = function () {
        console.log("点击2");
    }
    // 只打印"点击2",原因,只能绑定最后一个方法

    // 事件的移除
    div.onclick = null;


    // 非on事件的绑定 *
    // addEventListener('事件名', 回调函数, 冒泡方式)
    div.addEventListener('click', function() {
        console.log("点击1");
    });

    var fn = function() {
        console.log("点击2");
    }
    div.addEventListener('click', fn);
    // 存在重复绑定

    // 事件的移除
    // removeEventListener('事件名', 回调函数名)
    div.removeEventListener('click', fn)
    // 注:绑定与移除需要指向同一个方法(地址)

</script>
</html>

二.冒泡和默认事件

  • 冒泡: 子级父级都有点击事件时,子级区域点击,子级响应事件,但父级也响应
  • 阻止冒泡
 sub.onclick = function (ev) {
        // 方式1
        ev.stopPropagation();
        // 方式2
        // ev.cancelBubble = true;
        console.log("sub click");
    }
    sup.onclick = function (ev) {
        console.log("sup click");
    }

- 默认事件: 一些事件存在默认的系统动作,eg:鼠标右键会弹出菜单栏
- 取消默认

    sub.oncontextmenu = function (ev) {
        // 方式1
        // ev.preventDefault();
        console.log("sub menu click");
        // 方式2
        return false;
    }

code:

<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <title>冒泡和默认事件</title>
    <style type="text/css">
        .sub {
            width: 100px;
            height: 100px;
            background-color: red;
            position: absolute;
            left: 50px;
            top: 50px;
        }
        .sup {
            width: 200px;
            height: 200px;
            background-color: orange;
            position: relative;
            /*position: absolute;
            top: 50px;
            left: 100px;*/
            margin: 50px auto;
        }
        body {
            border: 1px solid black;
        }
    </style>
</head>
<body>
    <div class="sup">
        <div class="sub"></div>
    </div>
</body>
<script type="text/javascript">
    var sub = document.querySelector('.sub');
    var sup = document.querySelector('.sup');
    var body = document.querySelector('body');

    // 冒泡: 父子级拥有同一的事件,在子级区域触发子级事件,父级也能捕获并响应
    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");
    };


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

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


</script>
</html>

三.鼠标事件

onclick:鼠标点击
ondblclick:鼠标双击
onmousedown:鼠标按下
onmousemove:鼠标移动
onmouseup:鼠标抬起
onmouseover:鼠标悬浮  onmouseenter
onmouseout:鼠标移开  onmouseleave
oncontextmenu:鼠标右键

鼠标事件ev反馈的鼠标点
ev.clientX | ev.clientY
相当于页面原点(左上角)

code:

<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <title>鼠标事件</title>
    <style type="text/css">
        .div {
            width: 200px;
            height: 200px;
            background-color: orange;
            margin: 50px auto;
        }
    </style>
</head>
<body>
    <div class="div"></div>
</body>
<script type="text/javascript">
    var div = document.querySelector('.div');

    // 双击
    div.ondblclick = function () {
        console.log("双击了");
    }

    // 鼠标按下
    div.onmousedown = function () {
        console.log("按下");
    }
    // 鼠标抬起
    div.onmouseup = function () {
        console.log("抬起");
    }
    // 鼠标移动
    div.onmousemove = function (ev) {
        // 鼠标在页面中的位置
        console.log("x的坐标:", ev.clientX);
        console.log("y的坐标:", ev.clientY);
        console.log("移动");
    }


</script>
</html>

四.键盘事件

onkeydown: 键盘按下
onkeyup: 键盘抬起
// 绑定的对象: 对象自身不录入文本,绑给document,自身录入文本(表单标签),绑给自身

ev.keyCode

code:

<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <title>键盘事件</title>
    <style type="text/css">
        .div {
            width: 200px;
            height: 200px;
            background-color: red;
            /*margin: 50px auto;*/
            position: absolute;
            top: 0;
            left: 100px;
        }
    </style>
</head>
<body>
    <div class="div"></div>
</body>
<script type="text/javascript">
    var div = document.querySelector('.div');
    // 操作一般标签,键盘事件绑定给document
    // 表单标签(可以录入文本),键盘事件绑定给表单标签
    document.onkeydown = function (ev) {
        // console.log(ev.keyCode);
        switch(ev.keyCode) {
            case 37: 
                console.log("左");
                div.style.left = div.offsetLeft - 3 + "px";
                break;
            case 38: 
                console.log("上");
                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>
</html>
<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <title>键盘控制平滑运动</title>
    <style type="text/css">
        .div {
            width: 100px;
            height: 100px;
            background-color: red;
            position: absolute;
            top: 120px;
            left: 100px;
        }
    </style>
</head>
<body>
    <div class="div"></div>
</body>
<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>
</html>

五.表单事件

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

code:

<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <title>表单事件</title>
</head>
<body>
    <form action="">
        <input type="text" name="usr">
        <button type="submit">提交</button>
    </form>
    <div></div>
</body>
<script type="text/javascript">
    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;
    }

</script>
</html>

六、文档事件

  • 文档事件由window调用

    onload:页面加载成功
    onbeforeunload:页面退出或刷新警告,需要设置回调函数返回值,返回值随意

code:

<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <title>文档事件</title>
    <!-- 代码自身至下解析 -->
    <script type="text/javascript">
        var div = document.querySelector('div');
        console.log(div);  // null
    </script>
    <script type="text/javascript">
        // 文档加载完毕,触发
        window.onload = function () {
            var div = document.querySelector('div');
            console.log(div);
        }
    </script>
</head>
<body>
    <div class="div"></div>
</body>
<script type="text/javascript">
    window.onbeforeunload = function () {
        return false;
    }
</script>
</html>

七、图片事件

onerror:图片加载失败

code:

<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <title>图片事件</title>
</head>
<body>
    <img src="img/001.png" alt="">
</body>
<script type="text/javascript">
    var img = document.querySelector('img');
    img.onerror = function () {
        console.log("图片加载失败了");
    }
</script>
</html>

八、页面事件

onscroll:页面滚动
onresize:页面尺寸调整


window.scrollY:页面下滚距离
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,734评论 6 505
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,931评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,133评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,532评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,585评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,462评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,262评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,153评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,587评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,792评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,919评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,635评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,237评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,855评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,983评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,048评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,864评论 2 354