网页的键盘翻页功能

如果文档较长,用户每次阅读到文章末尾,都要回到目录树去点击,才能跳转到下一节。对用户来说,这样的应用就不是特别友好。

如果在每篇文章的末尾,增加到上一节和下一节的链接,就会很方便。如果用户可以通过键盘方向键,按 ← 键回到上一节,按 → 键跳转到下一节,那就更方便了。

我们的网页版 word 就支持键盘翻页功能,只需在文章的末尾增加上一节和下一节的链接,用户可以通过鼠标点击,也可以通过键盘操作进行跳转。HTML代码如下:

 
  1. <a id="prev" href="11.4.1.html"  title="← 键到上一节">上一节</a>
  2. <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() 的函数中,每个页面直接调用该函数即可。完整代码如下:

 
  1. function changePage() {
  2.     $(document).keydown (function(ev) {
  3.         var event = window.event || ev;
  4.         var code = event.keyCode || event.which;
  5.         if(code == 37)  // ← 的键盘码
  6.             window.location.href = $("#prev").attr("href");
  7.         if(code == 39)  // → 的键盘码
  8.             window.location.href = $("#next").attr("href");
  9.     });
  10. }

需要注意的是,在IE6中,不能保证所有的按键都能被 keydown 事件正确监测到,如果出现这种情况,请尝试使用 keyup 或者 keypress 事件。

关于作者

歪脖先生,十五年以上软件开发经验,酷爱Web开发,精通 HTML、CSS、JavaScript、jQuery、JSON、Python、Less、Bootstrap等,著有《HTML宝典》、《揭秘CSS》、《Less简明教程》、《JSON教程》、《Bootstrap2用户指南》、《Bootstrap3实用教程》,并全部在 GitHub 上开源。

功能是以读书管理为例子而实现翻页功能,目的希望大家很够很容易掌握它,同时将它学会。希望能给大家带来方便! Web应用开发的JavaServer Pages技术方法 在开发JSP规范的过程中,太阳微系统公司(Sun Microsystems Inc.)与许许多多主要的Web服务器、应用服务器和开发工具供应商,以及各种各样富有经验的开发团体进行合作。其结果是找到了一种为应用和页面开发人员平衡了可移植性和易用性的开发方法。 JSP技术在多个方面加速了动态Web页面的开发: 将内容的生成和显示进行分离 使用JSP技术,Web页面开发人员可以使用HTML或者XML标识来设计和格式化最终页面。使用JSP标识或者小脚本来生成页面上的动态内容(内容是根据请求来变化的,例如请求帐户信息或者特定的一瓶酒的价格)。生成内容的逻辑被封装在标识和JavaBeans组件中,并且捆绑在小脚本中,所有的脚本在服务器端运行。如果核心逻辑被封装在标识和Beans中,那么其他人,如Web管理人员和页面设计者,能够编辑和使用JSP页面,而不影响内容的生成。 在服务器端,JSP引擎解释JSP标识和小脚本,生成所请求的内容(例如,通过访问JavaBeans组件,使用JDBCTM技术访问数据库,或者包含文件),并且将结果以HTML(或者XML)页面的形式发送回浏览器。这有助于作者保护自己的代码,而又保证任何基于HTML的Web浏览器的完全可用性。 强调可重用的组件 绝大多数JSP页面依赖于可重用的,跨平台的组件(JavaBeans或者Enterprise JavaBeansTM组件)来执行应用程序所要求的更为复杂的处理。开发人员能够共享和交换执行普通操作的组件,或者使得这些组件为更多的使用者或者客户团体所使用。基于组件的方法加速了总体开发过程,并且使得各种组织在他们现有的技能和优化结果的开发努力中得到平衡。 采用标识简化页面开发 Web页面开发人员不会都是熟悉脚本语言的编程人员。JavaServer Page技术封装了许多功能,这些功能是在易用的、与JSP相关的XML标识中进行动态内容生成所需要的。标准的JSP标识能够访问和实例化JavaBeans组件,设置或者检索组件属性,下载Applet,以及执行用其他方法更难于编码和耗时的功能。 通过开发定制化标识库,JSP技术是可以扩展的。今后,第三方开发人员和其他人员可以为常用功能创建自己的标识库。这使得Web页面开发人员能够使用熟悉的工具和如同标识一样的执行特定功能的构件来工作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值