11.4.3 键盘翻页功能
优质
小牛编辑
133浏览
2023-12-01
如果文档较长,用户每次阅读到文章末尾,都要回到目录树去点击,才能跳转到下一节。对用户来说,这样的应用就不是特别友好。
如果在每篇文章的末尾,增加到上一节和下一节的链接,就会很方便。如果用户可以通过键盘方向键,按 ← 键回到上一节,按 → 键跳转到下一节,那就更方便了。
我们的网页版 word 就支持键盘翻页功能,只需在文章的末尾增加上一节和下一节的链接,用户可以通过鼠标点击,也可以通过键盘操作进行跳转。HTML代码如下:
<a id="prev" href="11.4.1.html" title="← 键到上一节">上一节</a>
<a id="next" href="11.4.3.html" title="→ 键到下一节">下一节</a>
这里,为上一节和下一节的链接添加了 title 属性,当用户鼠标悬停到链接上时,就会给用户提示 title 属性中的内容。对新用户来说,这个提示尤为重要。
要支持键盘操作,可以让 document 对象来监控键盘的 keydown 事件,并在事件处理函数中获取对应的键盘码,来区分用户按的是哪个键。得到键盘码后,再把链接的 href 属性值赋给 window.location.href 属性,便可以跳转到上一节或下一节。
在定义事件处理函数时,需要注意的是,IE浏览器不支持 function 的参数ev,需要通过 window.event 来获得事件;获得键盘码时,Firefox浏览器不支持 event.keyCode,而要使用 event.which。
为了方便使用,可以把处理过程封装在一个名为 changePage() 的函数中,每个页面直接调用该函数即可。完整代码如下:
function changePage() {
$(document).keydown (function(ev) {
var event = window.event || ev;
var code = event.keyCode || event.which;
if(code == 37) // ← 的键盘码
window.location.href = $("#prev").attr("href");
if(code == 39) // → 的键盘码
window.location.href = $("#next").attr("href");
});
}
需要注意的是,在IE6中,不能保证所有的按键都能被 keydown 事件正确监测到,如果出现这种情况,请尝试使用 keyup 或者 keypress 事件。