JS CustomEvent自定义事件传参小技巧

这篇文章发布于 2020年08月20日,星期四,21:46,归类于 JS API。 阅读 29408 次, 今日 24 次 20 条评论

 

CustomEvent自定义事件传参

自定义事件的传参主要是通过CustomEvent.detail进行的。

一、addEventListener事件触发

例如,给输入框元素(假设DOM对象变量名称是input)绑定了一个'input'事件,如下:

input.addEventListener('input', function () {
    // write by zhangxinxu
});

此时,点击下拉框希望触发输入框元素的'input'事件,就可以使用dispatchEvent方法和CustomEvent对象。

JS代码如下示意:

var myEvent = new CustomEvent('input');
input.dispatchEvent(myEvent);

也可以合在一起书写,JS代码如下:

input.dispatchEvent(new CustomEvent('input'));

如果希望触发'input'事件的同时传递下拉列表对应的参数对象给'input'事件,则可以使用CustomEvent.detail

语法示意如下:

var myEvent = new CustomEvent('input', {
    // zhangxinxu:
    // objParams就是需要传递的参数,
    // 可以是任意的类型
    detail: objParams
});
input.dispatchEvent(myEvent);

二、支持任意的自定义事件名称

不仅是浏览器原生的事件,如'click''mousedown''change''mouseover''mouseenter'等可以触发,任意的自定义名称的事件也是可以触发的。

例如:

document.body.addEventListener('文章勿盗', () => { console.log('文明、公正、法治、诚信'); });
// 触发
document.body.dispatchEvent(new CustomEvent('文章勿盗'));

结果如下图所示:

任意的自定义事件执行效果示意

传参也是一样的,例如:

document.body.addEventListener('show', (event) => { console.log(event.detail); });
// 触发
let myEvent = new CustomEvent('show', {
    detail: {
        username: 'zhangxinxu.com',
        userid: '20200820'
    }
});
document.body.dispatchEvent(myEvent);

运行后的结果参见下图:

自定义事件传参截图效果

三、IE浏览器不支持怎么办?

IE浏览器是不支持CustomEvent.detail的,Edge 14+才开始支持,怎么办,难道IE浏览器就不能使用的吗?

不急,可以用,增加一段Polyfill脚本就可以了,如下所示:

/**
 * CustomEvent constructor polyfill for IE
 */
(function () {
    if (typeof window.CustomEvent === 'function') {
        // 如果不是IE
        return false;
    }

    var CustomEvent = function (event, params) {
        params = params || {
            bubbles: false,
            cancelable: false,
            detail: undefined
        };
        var evt = document.createEvent('CustomEvent');
        evt.initCustomEvent(event, params.bubbles, params.cancelable, params.detail);
        return evt;
    };

    CustomEvent.prototype = window.Event.prototype;

    window.CustomEvent = CustomEvent;
})();

这段代码复制到页面中,放在具体的业务JavaScript代码的前面,否则可能会因为执行时机先后的问题导致出bug。

四、结语

最近没事搜自己写的文章,结果发现每一篇文章都被采集站收集了,没有原出处,也不留我姓名,搜索引擎排名比我还高,甚至有些文章某国产垃圾搜索引擎都没有我的名字。

这些网站居然还活着,还活得很好,居然排名还那么高,例如某某之家之类的网站,真的是很神奇,这种匪夷所思的现象自然离不开同样神奇的某度。

2021年元旦之后,新的民法典执行,对于知识产权侵犯已经允许惩罚性赔偿了,到时候,我一定直接律师函发过去,我在这里立贴为证!

(本篇完)

分享到:


发表评论(目前20 条评论)

  1. sk说道:

    敢不敢直接写 百度

  2. wenlong说道:

    支持维权,每个开发者的成果不能被这么盗窃

  3. 鱼小戈说道:

    张老师,有没有一种方式把参数传递给自定义的事件中。比如
    dispatchEvent(eventName,params),然后在new CustomEvent(“eventName”, {
    detail: {
    isFixed: params
    }
    });中可以拿到dispatchEvent()中的参数params

  4. XFE-Peter说道:

    支持维权。举手支持

  5. 说一说说道:

    强烈支持,必须维护自己的权益

  6. xiufu说道:

    支持维权!!

  7. 三花说道:

    微信小程序的事件似乎就是基于自定义事件

  8. jesse说道:

    抄袭可耻,支持原创。

  9. ziven27说道:

    支持原创

  10. 魔狼再世说道:

    我也支持,我前几天在博客园写了一个原创文章,然后不到1分钟别的站就有了

  11. miiix说道:

    百度真的业界毒瘤…

  12. null说道:

    为什么看不到自己的评论, 邮件地址没做浏览器缓存处理, 每次都要重新输入

  13. 123说道:

    支持维权

  14. yancy说道:

    支持维权

  15. 碧雪说道:

    支持大佬维权

  16. 青山说道:

    支持大佬维权,好不容易写的文章.让那些小人伸手拿去的确不公.

  17. 太想飞说道:

    支持大佬维权

  18. Korey说道:

    支持

  19. 闷闷不乐说道:

    ?,这种事情就是要有这种杠下去的精神,加油!

  20. LeonZou说道:

    就怕发律师函也没有用,人又找不到,最多百度降个排名