9月2号=》446页-450页

16.2.3  判断在线状态

    为了判断浏览器的在线状态,HTML5提供了两种方法来检测是否在线。

    navigator.onLine属性:navigator.onLine属性可返回当前是否在线。如果返回true,则表示在线;如果返回false,则表示离线。当网络发生变化时,

                navigator.onLine的值也随之变化。开发者可以通过读取它的值获取网络状态。

    onlne/ofline事件:如果开发者需要在网络状态发生变化时立刻得到通知,则可以通过HTML5提供的online/offine事件来检测。当在线/离线状态切换时,body元素

              上的online/offline事件将会被触发,并沿着document.body、document和window冒泡。因此,开发者可以通过它们的online/offline事件来检测网路状态的变化。

16.2.4  applicationCache对象

    开启离线应用之后,javaScript可以通过applicationCache来控制离线缓存,applicationCache接口包含了一个status属性,

    该属性可能返回如下几个状态值:

      UNCACHED:applicationCache对象所在的主机没有开启离线应用功能。

      IDLE:空闲状态。

      CHECKING:正在检测本地缓存的manifest文件与服务器端manifest文件的差异。

      DOWNLOADING:正在下载需要缓存的数据。

      UPDATEREADY:已经从服务器把需要缓存的文件下载到本地,但还未更新本地缓存。

      OBSOLETE:缓存已经过期。

    ApplicationCache接口中定义了如下两个常用方法。

      void update():该方法强制检查服务器上manifest文件是否有更新。

      void swapCache():该方法用于手动更新本地缓存。它只能在applicationCache对象的updateReady事件被触发时调用。

16.2.5  离线应用的事件与监听

    从上面关于applicationCache的介绍可以看出,在applicationCache的使用过程中会不断地触发一系列事件。

    下面简单介绍离线应用的相关事件,当浏览者第一次访问指定网站如http://localhost:8888/cacheQs/index.html页面时,完整过程如下。

      (1)浏览器请求http://localhost:8888/cacheQs/index.html页面。

      (2)服务器返回index.html页面。

      (3)浏览器检测该页面是否指定了manifes属性,如果没有指定该属性,则将不会有后面行为;如果指定了该属性,则触发checking事件,检查manifest属性所指定

          的manifest文件是否存在,如果不存在,则触发error事件,不会指定第6步及后续步骤。

      (4)浏览器解析index.html页面,请求该页面所引起的其他资源,例如JavaScript文件、图片等。

      (5)服务器返回所有被请求的资源。

      (6)浏览器开始处理manifest文件。重新向服务器请求manifest文件中列出的所有资源,包括index.html页面。虽然前面已经下载过这些资源,但此时依然要重新下载一遍。

      (7)服务器返回所有要求在本地缓存的资源。

      (8)浏览器开始下载需要在本地缓存的资源。开始下载时触发ondownloading事件;在下载过程中不断地触发onprogress事件,以方便开发人员了解下载进度。

      (9)下载完成后触发oncache事件,表明服务器缓存完成。

      当浏览器再次访问http://localhost:8888/cacheQs/index.html页面时,前面的第1~5步完全相同。接下来浏览器会检查新下载的manifest文件与本地缓存的manifest文件是否有改变:

        如果manifest没有改变,则触发onnoupdate事件,没有后续步骤。

        如果manifest文件有改变,则继续执行上面的第7、8步,当把所有需要在本地缓存的文件下载完成后,浏览器触发onupdateready事件,而不是触发oncached事件。

时间: 2024-12-22 18:05:12

9月2号=》446页-450页的相关文章

5月29号=》第41页-第45页

2.4 HTML5头部和元信息 <script>:该元素用于包含JavaScript脚本. <style>:该元素用于定义内部CSS样式. <link>:该元素用于链接外部CSS样式等资源. <title>:该元素用于定义文档标题. <base>:该元素用于指定该页面中所有链接的基准链接. 该元素属性如下: href:指定所有链接的基准链接. target:指定超链接默认在哪个窗口打开=>(_blank._parent._self._top

5月27号=》第30页-第35页

2.18 框架相关元素 HTML5删除了<frameset>.<frame>.<noframes>这三个标签 保留了<iframe>元素 2.2 HTML5新增的通用属性 2.2.1 contenEditable:该属性为true时可在页面直接对该标签进行编辑    用户编辑完后,内容会直接显示在该页面中(一旦  刷新页面就会重新加载,编辑的内容会丢失),开发  者可以通过该元素的innerHTML属性来获取编辑后    的内容   该属性具有"可

5月28号=》第35页-第40页

2.3.2 语义相关元素 <mark>:用于显示HTML页面中需要重点"关注"的内容,浏览器 通常会用黄色显示该标签内的内容. <time>:用来显示被标注内容是日期.时间或者日期时间.   使用该标签要指定datetime属性,格式为"yyyy-MM-ddTHH:mm"   如果<time>标签的内容直接符合以上格式,则可以不用指定datetime属性. <details>:该元素用于显示一段详细信息或某个主题的细节

6月11号=》121页-125页

6.1 样式单概述 W3C已经给出了两种样式单语言的推荐标准,一种是级联样式单CSS(Cascading Style Sheets), 另一种是可扩展样式单语言XSL(eXtensible Stylesheet Language). 6.1.1 CSS CSS主要提供如下两个功能: 1:对页面的字体.颜色控制更加细腻,让页面内容更富表现力,CSS的表现效果远远超出 传统HTML页面的color.bgcolor等属性的表现力. 2:通过CSS控制整站风格,CSS样式单可以同时控制整个站点所有页面的

8月19号=》436页-440页

16.1 Web Storage 在传统的HTML时代,浏览器的主要功能只是负责展现HTML页面,即使增加了JavaScript脚本,依然只是为动态地修改HTML页面服务.因此 浏览器只是一个“界面呈现工作”. 如果开发者需要在客户端存储少量数据,早起只能通过Cookie来实现,但Cookie存在如下3点不足: Cookie的大小被限制为4KB. Cookie会包含在每个HTTP请求中向服务器发送,这样势必导致多次发送重复数据. Cookie在网络传输时并未加密(除非整个应用都使用SSL),因此

8月11号=》386页-390页

14.9 navigator和地理位置 window对象有一个navigator属性,该属性对应于Navigator对象,该对象代表浏览该页面所使用的浏览器.该对象在不同 的平台上的信息并不完全相同,但总包含如下几个常用的属性. appName:返回该浏览器的内核名称. appVersion:返回该浏览器当前的版本号. platform:返回当前浏览器所在的操作系统. 14.9.1 HTML5新增的geolocation属性 HTML5为navigator新增了一个geolocation属性,这

8月5号=》346页-350页

13.11 创建对象 JavaScript中创建对象可以不用使用任何累.JavaScript中创建对象大概有3中方式. 13.11.1 使用new关键字调用构造器创建对象 代码示范: //定义一个函数,同时也定义了一个Person类 function Person(name,age) { this.name = name; this.age = age; } //使用new关键字创建Person实例 var p1 = new Person("张三",18); //输出该对象的属性值 a

7月29号=》301页-305页

13.5 运算符 JavaScript提供了相当丰富的运算符,运算符也是JavaScript语言的基础. 通过运算符,可以将变量连接成语句,语句是JavaScript代码中的执行单位. 下面依次介绍JavaScript中的运算符. 13.5.1 赋值运算符 =:即var num = 1; 13.5.2 算术运算符 +:即1+2 =3; -:即2-1 = 1; *:即2*2 =4; /:即4/2 = 2; %:即3%2=1; 13.5.3 位运算符 &:按位与. |:按位或. ~:按位非. ^:按

7月23号=》261页-265页

12.1 CSS3提供的变形支持 CSS3提供的变形支持可以对HTML组件进行常见的几何变换,包括旋转.缩放.倾斜.位移 4中变换,也可以使用变换矩阵进行变形. CSS3为变形支持提供了如下两个属性值. transform:该属性用于设置变形.该属性支持一个或多个变形函数.CSS3提供了如下变形函数. translate(tx [,ty]):该函数设置HTML组件横向上移动tx距离,纵向上移动ty距离.其中ty参数 可以省略,如果省略ty参数,则ty默认为0,表明纵向上没有位移. transla