问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

怎么实现js跨浏览器获取鼠标按键的值

发布网友 发布时间:2022-05-16 07:20

我来回答

2个回答

懂视网 时间:2022-05-16 11:41

js实现一些跨浏览器的事件方法

  用JavaScript实现事件的绑定,移除,以及一些常用的事件属性的获取,时常要考虑到在不同浏览器下的兼容性,下面给出了一个跨浏览器的事件对象:

 var EventUtil = { 
 on: function(element, type, handler) {/* 添加事件 */
 if (element.addEventListener) {
 element.addEventListener(type, handler, false);
 } else if (element.attachEvent) {//IE 注意:此时事件处理程序会在全局作用域中运行,因此用attachEvent绑定的事件,此时在事件处理函数里的this 等于window,使用时要注意
 element.attachEvent("on" + type, handler);
 } else {
 element["on" + type] = handler;
 }
 },
 
 off: function(element, type, handler) {/* 移除事件 */
 if (element.removeEventListener) {
 element.removeEventListener(type, handler, false);
 } else if (element.detachEvent) {
 element.detachEvent("on" + type, handler);
 } else {
 element["on" + type] = null;
 }
 },
 
 getEvent: function(event) {/* 返回对event对象的引用 */
 return event ? event : window.event;
 },
 
 getTarget: function(event) {/* 返回事件的目标 */
 return event.target || event.srcElement;
 },
 
 preventDefault: function(event) { /* 取消事件的默认行为 */
 if (event.preventDefault) {
 event.preventDefault();
 } else {
 event.returnValue = false;
 }
 },
 
 stopPropagation: function(event) {/* 阻止事件冒泡 */
 if (event.stopPropagation) {
 event.stopPropagation();
 } else {
 event.cancelBubble = true;
 }
 },
 
 /* mouseover 和mouserout 这两个事件都会涉及把鼠标指针从一个元素的边界之内移动到另一个元素的边界之内。*/
 getRelatedTarget: function(event) {
 if (event.relatedTarget) {
 return event.relatedTarget;
 } else if (event.toElement) {//IE8 mouserout事件
 return event.toElement;
 } else if (event.fromElement) {//IE8 mouseover事件
 return event.fromElement;
 } else {
 return null;//其他事件
 }
 }
};

调用如下:

EventUtil.on(document, "click", function(event){//为document元素绑定click事件
 event = EventUtil.getEvent(event);//获取event事件对象
 alert("Screen coordinates: " + event.screenX + "," + event.screenY);
});

热心网友 时间:2022-05-16 08:49

通过js 跨浏览器获取鼠标按键的值的方法
document.onmousedown = function( e ){
alert(getButton(e)) // e.button W3C是获取鼠标按键 0 表示左键 1表示中键 2表示右键
而IE浏览器则是 1表示左键 4表示中间 2表示右键 这里的IE浏览器主要是IE8以下的浏览器
};
function getButton(e){
/*
1、window.event这个属性IE和Chrome都是支持的
2、但是Chrome也是支持W3C的
3、所以,如果说W3C和IE都支持的话,那么就已W3C做为标准化
*/
if( e ){ // 作为第一次判断Chrome 就以W3C为标准了,去年远标java就说到这个问题。
return e.button;
}else if( window.event ){
switch( window.event.button ){
case 1 : return 0; // 返回鼠标左键的值
case 4 : return 1; // 返回鼠标中键的值
case 2 : return 2; // 返回鼠标右键的值
case 0 : return 2; // 返回鼠标右键的值 主要是360浏览器会返回了 在IE浏览器中
返回的0是代表没有按下鼠标键的时候所返回来的值
};
};
};
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
门?049期父母欲其改娶五字金口决,开是什么特号生肖 支付宝怎么把银行卡的钱转到余额里呢? 下载wampserver5,安装并启动后不能启用apache、mysql的功能,请问这是怎... wampserver安装多个版本phpmysqlapache 四季豆有哪些吃法值得推荐? 四季豆牛肉馅饼的家常做法是什么? 香煎四季豆豆腐饼怎么做好吃 腾讯会议没声音怎么修复-腾讯会议没有声音修复办法 西安市高新区所有幼儿园 西安高新第二初级中学学区有哪些小区 名字里带一个渊字好不好 一个八十多岁病恹恹的房客独租房,签了免责协议,能不能租给他,主要怕死家里以后租不出去? 武汉滴滴公司地址 滴滴出行科技有限公司武汉分公司怎么样? 入禅是什么意思 久的组词 什么是起承转合?怎么才能做到绅士君子风度有魅力(其实我就是想做到... 禅什么意思 连个离婚的都不愿意跟我做对象。也没见面,就说了家庭条件。现在想去死。25了。这手相能活多久 生活情感,个人发展问题,迷茫的我。 打坐虽不是禅,久做必能生禅 BBF来帮帮我~~~ 我24岁了,还没有真正恋爱过的可怜男人 - 信息提示 “久坐必生禅”的科学依据是什么 久坐必有禅下一句 久等必有一善谚语 “久等必有惮”怎么解释 久等必有一禅 什么意思 2022最新抗疫诗词 业渊的寓意 渊字取名好不好 菅皓渊这个名字的意义 诚请专业人士帮忙解答:尼龙6这种材质做成的布料,用100度的开水烫过以后,是否会产生对人体有害的毒素? 尼龙6的熔融指数是多少? 尼龙料手感软会影响幅宽吗 如何让女生倒追你? 想去找个道观短期修行,多则一年半载,少则十天半月,给香火钱什么的都行,求推荐,最好是有联系的路子。 哪里有免费修行道场 如何让女生主动追你? 正一派道姑住道观免费吗? 可以短暂修行的道观 哪里有深山老林的小寺庙或者道观人群和善可以免费长居的能接受女生 辽宁哪里有道观 哪里可以出家、是修行那种道观?而且不要钱的、 山东有哪些可以修行的清静的小道观,想入道,离世俗? 哪个道观可以短期修行. 寻世外桃源有道观或寺庙的、要招收弟子的、吃穿住全免费的、、、我代发修行两年、刚好寄宿化缘、禅悟人生 想找个寺庙或者道观住几天,有推荐的吗 现在在哪里可以皈依道教,在家修行呢?哪里的道教宫观才可以接纳新弟子入教呢?