最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

JavaScript滚轮事件使用说明_javascript技巧

来源:动视网 责编:小采 时间:2020-11-27 20:47:47
文档

JavaScript滚轮事件使用说明_javascript技巧

JavaScript滚轮事件使用说明_javascript技巧:不过遗憾的是各浏览器都不尽相同。 一) 事件名称不相同 IE, KHTML(Safari, Chrome), Opera对应的事件名称是 mousewheel。而 Gecko(Firefox, Netscape) 对应的事件名称是 DOMMouseScroll。 二) 事件对象的属性不一样 有时我们需要知道用
推荐度:
导读JavaScript滚轮事件使用说明_javascript技巧:不过遗憾的是各浏览器都不尽相同。 一) 事件名称不相同 IE, KHTML(Safari, Chrome), Opera对应的事件名称是 mousewheel。而 Gecko(Firefox, Netscape) 对应的事件名称是 DOMMouseScroll。 二) 事件对象的属性不一样 有时我们需要知道用


不过遗憾的是各浏览器都不尽相同。

一) 事件名称不相同
IE, KHTML(Safari, Chrome), Opera对应的事件名称是 "mousewheel"。而 Gecko(Firefox, Netscape) 对应的事件名称是 "DOMMouseScroll"。

二) 事件对象的属性不一样
有时我们需要知道用户是向上滚了还是向下滚了。例如我们有一个响应滚动事件的函数:
代码如下:
function wheelHandle(e) {
if(e.wheelDelta) {// IE, KHTML, Opera
alert(e.wheelDelta > 0 ? '向上滚' : '向下滚');
} else { // Gecko
alert(e.detail < 0 ? '向上滚' : '向下滚');
}
}

IE, KHTML 支持 e.wheelDelta ,大于 0 为向上滚动,小于 0 为向下滚动。Gecko 支持 e.detail,小于 0 为向上滚动,大于 0 为向上滚动,跟前面的相反。而 Opera 比较牛,两种都支持。
下面给出一个注册滚轮事件的函数做参考:
代码如下:
/**
* 注册滚轮事件函数
* @param element : 注册的事件对象
* @param wheelHandle : 注册事件函数
*/
function addScrollListener(element, wheelHandle) {
if(typeof element != 'object') return;
if(typeof wheelHandle != 'function') return;
// 监测浏览器
if(typeof arguments.callee.browser == 'undefined') {
var user = navigator.userAgent;
var b = {};
b.opera = user.indexOf("Opera") > -1 && typeof window.opera == "object";
b.khtml = (user.indexOf("KHTML") > -1 || user.indexOf("AppleWebKit") > -1 || user.indexOf("Konqueror") > -1) && !b.opera;
b.ie = user.indexOf("MSIE") > -1 && !b.opera;
b.gecko = user.indexOf("Gecko") > -1 && !b.khtml;
arguments.callee.browser = b;
}
if(element == window)
element = document;
if(arguments.callee.browser.ie)
element.attachEvent('onmousewheel', wheelHandle);
else
element.addEventListener(arguments.callee.browser.gecko ? 'DOMMouseScroll' : 'mousewheel', wheelHandle, false);
}

注册一个监听事件:
代码如下:
var display = document.getElementById('display');
function wheelHandle(e) {
if(e.wheelDelta) {// IE, KHTML, Opera
display.innerHTML = (e.wheelDelta > 0 ? '上' : '下');
} else { // Gecko
display.innerHTML = (e.detail < 0 ? '上' : '下');
}
}
addScrollListener(window, wheelHandle);

文档

JavaScript滚轮事件使用说明_javascript技巧

JavaScript滚轮事件使用说明_javascript技巧:不过遗憾的是各浏览器都不尽相同。 一) 事件名称不相同 IE, KHTML(Safari, Chrome), Opera对应的事件名称是 mousewheel。而 Gecko(Firefox, Netscape) 对应的事件名称是 DOMMouseScroll。 二) 事件对象的属性不一样 有时我们需要知道用
推荐度:
标签: 方法 技巧 事件
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top