中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

HTML5中Web緩存和運用程序緩存的示例分析

發布時間:2021-08-11 09:46:58 來源:億速云 閱讀:106 作者:小新 欄目:web開發

這篇文章主要為大家展示了“HTML5中Web緩存和運用程序緩存的示例分析”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“HTML5中Web緩存和運用程序緩存的示例分析”這篇文章吧。

session:

由于HTTP是無狀態的,你是誰?你干了什么?抱歉服務器都是不知道的。

因此session(會話)出現了,它會在服務器上存儲用戶信息以便將來使用(比如用戶名稱,購物車購買商品等)。

但是session是臨時的,用戶離開網站將被刪除。如果要永久存儲信息,可以保存在數據庫中!

session工作原理:為每個用戶創建一個session id(核心!!!)。而session id是存儲在cookie中的,也就是說如果瀏覽器禁用了cookie,那么session會失效!(但是可以通過其它方式實現,如:通過URL傳遞session id)

用戶驗證一般采用session。

cookie:

目的:網站標記用戶身份而存儲在本地客戶端的數據(通常經過加密)。

  1. 用戶訪問網頁時,名字記錄在cookie中;

  2. 下次繼續訪問該網頁時,可以從cookie中讀取用戶訪問記錄。

cookie會在同源的http請求攜帶(即使不需要),即在客戶端和服務器之間來回傳遞!

cookie的數據大小不超過4k

cookie的有效期:設置的cookie有效時間之前一直有效,即使瀏覽器關閉!

localStorage & sessionStorage:

早期,本地緩存普遍使用的是cookie,但是web存儲需要更安全、更快速!

這些數據不會保存在服務器上(存儲在客戶端),不會影響服務器性能!

sessionStorage和localStorage數據存儲也有大小限制,但卻比cookie大得多,可以達到5M甚至更大!

localStorage:沒有時間限制的數據存儲!

sessionStorage:由英文意思也可知,它是對session的數據存儲,所以在用戶關閉瀏覽器(標簽頁/窗口)后,數據被刪除!

HTML5 web存儲支持情況:

IE8以上,現代瀏覽器。

數據以鍵值對存儲:

localStorage和sessionStorage都有以下幾個方法:

  1. localStorage.setItem(key,value):設置(保存)數據;相當于localStorage.key=value!

  2. localStorage.getItem(key):獲取數據

  3. localStorage.removeItem(key):刪除單個數據

  4. localStorage.clear():刪除所有數據

  5. localStorage.key(index):獲取某個索引的鍵值

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>web storage</title>
</head>

<body>
    <div id="test"></div>
    <script>
        if (typeof (Storage) != undefined) {
            localStorage.name = 'xiao ming';
            localStorage.setItem('name1', 'Apple');
            document.getElementById('test').innerHTML = "you are: " + localStorage.name;
            console.log("first:" + localStorage.name1 + "," + localStorage.key(0));
            localStorage.removeItem('name1');
            console.log("second: " + localStorage.name1);
            console.log("third: " + localStorage.getItem('name'));
            localStorage.clear();
            console.log("last:" + localStorage.name);
        } else {
            document.getElementById('test').innerHTML = "更新瀏覽器吧!目前瀏覽器不支持stroage";
        }
        
    </script>
</body>
</html>

程序運行結果:

HTML5中Web緩存和運用程序緩存的示例分析

注意:鍵值對是以字符串保存的,根據需求應改變類型(比如做加法,變為Number型)。

 HTML5運用程序緩存(Application Cache):

通過創建cache manifest文件,web運用可被緩存,并且無網絡狀態可以進行訪問!

Application Cache優勢:

1.離線瀏覽;
2.速度更快:已緩存資源加載更快;
3.減少瀏覽器負載:客戶端將只從服務器下載或更新更改過的資源

支持情況:

IE10以上,現代瀏覽器。

使用:

<!DOCTYPE html>
<html manifest="demo.appcache">
</html>

注意:要開啟application cache,需指定manifest屬性(擴展名:.appcache);如果未指定manifest屬性,頁面不會緩存(除非在manifest文件中直接指定了該頁面!)

manifest文件在服務器上需正確的配置MIME-type:text/cache-manifest。

Manifest文件:

manifest是簡單的文本文件,它告知瀏覽器被緩存的內容以及不被緩存的內容!

manifest可分為三部分:

CACHE MANIFEST:此項列出的文件將在首次下載后進行緩存!

NETWORK:此項列出的文件需要與服務器進行網絡連接,不會被緩存!

FALLBACK:此項列出當頁面無法訪問時的回退頁面(如:404頁面)!

test.appcache:

CACHE MANIFEST
#2017 11 21 v10.0.1
/test.css
/logo.gif
/main.js

NETWORK
/login.php
/register.php

FALLBACK
#/html/目錄中文件無法訪問時,用/offline.html替代
/html/ /offline.html

更新application cache的情況:
1.用戶清空瀏覽器緩存!
2.manifest文件被更改(#:表示注釋,同時如果更改為#2018 1 1 v20.0.0,則瀏覽器會重新緩存!)
3.程序進行更新application cache!

Web Workers:

web workers是運行在后臺的javascript,獨立于其它腳本,不會影響頁面性能!

而一般的HTML頁面上執行腳本時,除非腳本加載完成,否則頁面不會響應!

支持情況:IE10以上,現代瀏覽器

示例:html文件:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>web worker</title>
</head>
<body>
    <p>計數:<output id="count"></output></p>
    <button onclick="startWorker()">開始</button>
    <button onclick="overWorker()">結束</button>

    <script>
        var w;
        function startWorker(){
            // 檢測瀏覽器是否支持web worker
            if(typeof(Worker)!=='undefined'){
                if(typeof(w)=='undefined'){
                    //創建web worker對象
                    w=new Worker('testWorker.js');
                }
                // 事件持續監聽(即使外部腳本已經完成),除非被終止
                w.onmessage=function(event){
                    document.getElementById('count').innerHTML=event.data;
                };
            }else{
                document.getElementById('count').innerHTML='瀏覽器不支持web worker';
            }
        }
        function overWorker() {
            // 終止web worker對象,釋放瀏覽器/計算機資源
            w.terminate();
            w=undefined;
        }
    </script>
</body>
</html>

testWorker.js文件:

var i=0;
function timedCount() {
    i+=1;
    // 重要的部分,向html頁面傳回一段信息
    postMessage(i);
    setTimeout('timedCount()',500);
}
timedCount();

注意1:通常web worker不是用于如此簡單的任務,而是用在更耗CPU資源的任務!

注意2:在chrome中運行會產生“cannot be accessed from origin 'null'”的錯誤,我的解決方法是:xampp中開啟apache,用http://localhost/進行訪問。

web worker缺點:

由于web worker位于外部文件中,所以它無法訪問下列javascript對象:

  1. window對象;

  2. document對象;

  3. parent對象。

HTML5 server-sent events(服務器發送事件):

server-sent事件是單向信息傳遞;網頁可以自動獲取來自服務器的更新!

以前:網頁先詢問是否有可用的更新,服務器發送數據,進行更新(雙向數據傳遞)!

支持情況:除IE以外的現代瀏覽器均支持!

示例代碼:html文件:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>sever sent event</title>
</head>
<body>
    <p>sever sent event informations</p>
    <div id="test"></div>
    <script>
        // 判斷瀏覽器是否支持EventSource
        if(typeof(EventSource)!==undefined){
            // 創建EventSource對象
            var source=new EventSource("test.php");
            // 事件監聽
            source.onmessage=function(event){
                document.getElementById('test').innerHTML+=event.data+"<br>";
            };
        }else{
            document.getElementById('test').innerHTML="sorry,瀏覽器不支持server sent event";
        }
    </script>
</body>
</html>

test.php:

<?php
header('Content-Type:text/event-stream');
header('Cache-Control:no-cache');

$time=date('r');
echo "data:The server time is: {$time} \n\n";
// 刷新輸出數據
flush();

注意:后面沒有內容,php文件可以不用"?>"關閉!

HTML5 WebSocket:

  1. WebSocket是HTML5提供的一種在單個TCP連接上建立全雙工(類似電話)通訊的協議;

  2. 瀏覽器和服務器之間只需要進行一次握手的操作,瀏覽器和服務器之間就形成了一條快速通道,兩者之間就可直接進行數據傳送;

  3. 瀏覽器通過javascript建立WebSocket連接請求,通過send()向服務器發送數據,onmessage()接收服務器返回的數據。

 WebSocket如何兼容低瀏覽器:

  1. Adobe Flash Socket;

  2. ActiveX HTMLFile(IE);

  3. 基于multipart編碼發送XHR;

  4. 基于長輪詢的XHR

WebSocket可以用在多個標簽頁之間的通信!

以上是“HTML5中Web緩存和運用程序緩存的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

九江市| 海宁市| 榆林市| 贵定县| 石渠县| 嘉峪关市| 三原县| 贵阳市| 如皋市| 石河子市| 丹寨县| 芜湖市| 昆明市| 临安市| 武威市| 调兵山市| 色达县| 铜川市| 皋兰县| 凭祥市| 雷波县| 庆城县| 拉萨市| 屯门区| 于田县| 嘉峪关市| 和田市| 罗定市| 石首市| 乌海市| 故城县| 新津县| 望江县| 江城| 来宾市| 淮北市| 酒泉市| 靖江市| 库尔勒市| 吴川市| 偏关县|