《jQuery Mobile入门经典》—— 2.3 使用JavaScript完成功能

简介:

本节书摘来异步社区《jQuery Mobile入门经典》一书中的第2章,第2.3节,作者:【美】Phil Dutson,更多章节内容可以访问云栖社区“异步社区”公众号查看。

2.3 使用JavaScript完成功能

jQuery Mobile入门经典
我们现在知道如何在网站中使内容具备样式——如果可以在访问者来查看网站的时候让某些事情发生,那可能会挺好。这就是JavaScript发挥作用的地方。

起初,在JavaScript开始引入的时候,获得了一个不好的名声。人们不理解它是什么,或者它有什么用处。我记得我的一个朋友确信他中了病毒,因为每次他访问某一网站的时候,单词会跟随他的鼠标在屏幕上围绕。

对许多人来说,JavaScript成为令人讨厌的东西,充其量不过是一个制造恶作剧的语言。在那个时候,还没意识到JavaScript能做什么,或者还没意识到它如何能通过添加动画、数据收集和事件绑定等来改变用户与网站交互方式的这些用法来丰富网站。虽然我够忙了,但还是让我再打破一个传说,JavaScript不是Java。

不管您有没有意识到,今天的JavaScript对文档对象模型(DOM)所做的操作比以往任何时候都多。那些只能使用预编译文件和特别的回放插件来完成的网站,现在可以在浏览器中原生地显示。JavaScript有助于让网站感觉起来更具交互性,或甚至更像一个原生应用程序。

2.3.1 何处可以添加脚本

可以通过在script标记中放置代码来包含JavaScript。虽然这些标记可以放置在文档内部的任何地方,但应该花些时间考虑一下脚本放在哪里会最有效。

1.Head元素
把script元素放置在head元素中可能会造成阻塞,但可确保代码在网页的其余部分载入之前准备就绪或已经执行。那些提供第三方监测“像素”或监测服务方面有经验的开发者会知道他们希望监测像素尽可能出现在网页顶部的位置。在head元素中放置一段脚本确保了它会载入,因为在继续载入网页的剩余部分之前,必须等待这段脚本已经下载完毕。

在head元素中载入脚本这种方法有一些缺点。如果调用的脚本在远程服务器上,可能最终要等待其载入完毕。由于一些浏览器只允许同时拥有两个URL数据的请求,这会阻止其中一个请求,导致网站中其余的元素载入相当缓慢。

2.中部
可以尝试在body元素中载入脚本。我看过正在调试的开发者这样做,并且从来不清除他们的测试脚本。我同样看到过这样使用的开发者,他们认为刚好在他们需要执行脚本的位置下方包含脚本是一个好主意。

尽管保持脚本接近操作或调用方法的地方看起来是一个好主意,但这可能使网站和网页维护变成一个噩梦。努力找出破坏网站或Web应用程序的代码在哪里可不是什么有趣的事(特别在已编译的代码中,行号不一定反映预编译文件中的实际行号)。

3.body的末尾
最后一个可以包含脚本的地方是body结束标记的正上方。在这里放置的脚本,在任何已包含的JavaScript文件因为缓慢载入远程文件而拖慢URL请求之前,使网页的其余部分开始生成。这让用户感觉到这是一个快速和有响应的网站,因为他们可以看到网页开始渲染,甚至在网页请求并载入它所需的功能之前就已开始渲染。

这种方法的缺点是,如果依赖在网页载入时应用的其余功能,以及依赖将触发事件的用户点击,而所使用的事件在JavaScript文件中创建,那么事件可能不会被绑定,所以这个点击动作将被浪费掉或将表现为一个错误。

在文档中放置JavaScript标记的小结。

在head元素中载入脚本,使得它们首先载入,但可能对可感知的载入时间有不利影响。
在body内部载入脚本,可能看起来是一个好办法,但会造成维护上的问题和潜在的载入延迟。
在body的结束标记之前载入脚本,使网站显得加载迅速,但可能得到非预期的结果,例如在最初的前几秒网站会缺失功能。

2.3.2 载入脚本

可以使用一个外部 .js文件的引用来包含JavaScript,或者在script元素中包含代码。这些引用应当包含在head元素或body元素中。

可以按如下方式引用外部文件的脚本标记。

e28ab0a440db55e44d599759735ed725b7c2b691

值得注意的是,可以用这种方法包含多于一个JavaScript文件,并且JavaScript文件可以从本地和远程位置进行包含。

如果需要把JavaScript代码直接包含在网页中,可以在script标记中包含。

设置类型

如果已经看过许多网站的源代码,很可能会注意到一些网站在script标记中缺少"type=text/javascript"的声明。可以选择包含它(依照HTML 4规范)或者省略它,因为所有现代浏览器已经知道在script元素内部的任何语句都是JavaScript。
程序清单2.7是一个HTML页面,包含一个示例函数,功能为查找一个id为"year"的元素,并以当前年份替换掉这个元素里面的内容。

程序清单2.7 javascriptdate.html文件

02a2a636928fe8e1a37c8c1a2127d2c8a725fb2a

第14行可以看到script元素的开始标记。在第15行,使用了window对象和onload方法,并把此方法设置为setYear。这是想要在网页载入的时候运行的函数的名称。第16行是setYear函数的声明。在第17行,创建了一个名为currentYear的变量,并将其值设置为Date对象。第18行,把功能整合起来,使用document.getElementbyId('year')从文档对象模型中解析并找到一个id为“year”的元素。接着通过使用.innerHTML = currentYear.getFullYear();,可以把找到的元素的值改为与当前年份相等。

关于这个代码示例,值得注意的是,Date对象是从客户机获取的。这意味着如果某人没有正确地设置好时间,那么网站上显示的年份只反映计算机认为的任何年份。正因为如此,使用JavaScript设置日期不是一个好主意。只要可能,尽量使用服务器时间而不是客户机时间。

图2.4展示了javascriptdate.html的代码在浏览器中渲染后的效果,已设置年份为2011。注意到它已经把年份由2000改为2011。

可以使用JavaScript做的事情不只是简单的数据操作。实际上,可以使元素在被单击时做一些事情。

018988189d327f918ae3cdefa07749d2f5669f30

2.3.3 事件绑定

JavaScript用来做的一件事情就是绑定事件。事件绑定在想要使鼠标单击触发一个函数或提交一个表单的时候非常有用。

程序清单2.8是一个在JavaScript中绑定事件的示例。

程序清单2.8 javascriptalert.html文件的代码片段

ce0f3c440838810a1ef304c751e92d3447b2abce

第1行是script元素的开始。在第2行,使用document.getElementById("btnAlert")来获得id为“btnAlert”的元素,接着通过附加.addEventListener('click', clickAlert, false)来给它绑定单击事件。第3行,开始创建clickAlert函数。第4行是对alert函数的调用。传入alert函数的值将会通过渲染此网站的浏览器显示在一个对话框窗口中。第5行是clickAlert函数的结束符大括号,终止了当函数运行时将会执行的代码。第6行就是script元素的结束标记。

在图2.5中,看到一个显示“You clicked the button!”信息的警告窗口。这个窗口的外观会有一些微小的不同,取决于每当alert()函数被调用的时候,正在使用的浏览器和操作系统。

24警告:小心alert()函数

使用alert()函数会在网页上显示一个对话框窗口。这是一个程序控制的信息,阻止用户使用网站,直到该信息被确认。某些浏览器会检测对于此函数
的多次调用,并给用户忽略掉所有警告的机会。由于这个原因,应该考虑通过使用“灯箱”(light box)或模态窗口实现无打扰式的信息提示。

52715fbad28abc1107c7210b90c156f262c6cbf9
相关文章
|
15天前
|
JavaScript 容器
带方向感知功能的js图片遮罩层插件
带方向感知功能的js图片遮罩层插件
|
2月前
|
JavaScript 前端开发
js+jquery实现贪吃蛇经典小游戏
本项目采用HTML、CSS、JavaScript和jQuery技术,无需游戏框架支持。通过下载项目文件至本地,双击index.html即可启动贪吃蛇游戏。游戏界面简洁,支持方向键控制蛇移动,空格键实现游戏暂停与恢复功能。
69 14
|
2月前
|
JavaScript 前端开发 容器
jQuery多功能滑块插件r-slider.js
r-slider.js是一款jQuery多功能滑块插件。使用该插件,可以制作出滑块、开关按钮、进度条、向导步骤等多种效果。
42 5
|
2月前
|
JavaScript
js实现简洁实用的网页计算器功能源码
这是一款使用js实现简洁实用的网页计算器功能源码。可实现比较基本的加减乘除四则运算功能,界面简洁实用,是一款比较基本的js运算功能源码。该源码可兼容目前最新的各类主流浏览器。
28 2
|
3月前
|
人工智能 JavaScript 网络安全
ToB项目身份认证AD集成(三完):利用ldap.js实现与windows AD对接实现用户搜索、认证、密码修改等功能 - 以及针对中文转义问题的补丁方法
本文详细介绍了如何使用 `ldapjs` 库在 Node.js 中实现与 Windows AD 的交互,包括用户搜索、身份验证、密码修改和重置等功能。通过创建 `LdapService` 类,提供了与 AD 服务器通信的完整解决方案,同时解决了中文字段在 LDAP 操作中被转义的问题。
|
3月前
|
JavaScript 前端开发 开发者
jQuery:JavaScript库的瑰宝
jQuery:JavaScript库的瑰宝
70 3
|
3月前
|
JavaScript 前端开发 API
|
3月前
|
JavaScript API UED
vue.js怎么实现全屏显示功能
【10月更文挑战第7天】
54 1
|
3月前
|
JavaScript 搜索推荐
JS中的模糊查询功能
JS中的模糊查询功能
48 1
|
3月前
|
JavaScript 前端开发 API
深入了解jQuery:快速、高效的JavaScript库
【10月更文挑战第11天深入了解jQuery:快速、高效的JavaScript库
38 0