zoukankan      html  css  js  c++  java
  • HTML5本地存储

    前言     

          本地持久化存储一直是本地客户端程序优于 web 程序的一个方面。对于本地应用程序,操作系统会提供一个抽象层,用于存储和获取特定于应用程序的数据,例如用户设置或者运行时状态。这些值可以被存储于注册表、INI 文件,或者其他什么地方,这取决于操作系统的实现。如果你的本地应用程序需要的不是简单的键值对形式的本地存储,你也可以使用嵌入式数据库、发明你自己的文件格式,或者其他很多种解决方案。

    然而,web 应用程序就没这些优点了。于是在 web 早期我们就发明了 cookie,目的是在本地持久存储少量数据。但是,cookie 有三个致命缺点:

       1.cookie 会包含进每一个 HTTP 请求,因此会减慢 web 应用程序,产生不必要的重复数据;

        2.cookie 会包含进每一个 HTTP 请求,因此网络上发送的数据就不能加密(除非你的整个应用都是用的 SSL)

        3.cookie 限制数据大小为 4 KB——这已经足以降低你的应用程序的速度,但是 4 KB 的大小有时候确实会

           捉襟见肘。

    在HTML5之前,还有其他一些解决方案。userData(用户数据)是IE的东西,只有IE6~IE9支持,而且存储在XML文件里。然后是2002年,Adobe 在 Flash 6 引入了一项新的特性 Flash cookie,空间是Cookie的25倍,基本够用,到2007年,Google 提供了 Gears,一个开源的浏览器插件,旨在为浏览器提供额外的功能。Gears 提供了一组基于 SQLite 的嵌入式数据库的 API。只要用户一次授权,Gears 能够按照域名在 SQL 数据库表中存储无限大小的数据。为了解决浏览器端存储只有4K大小,请求头常带存储信息,关系型存储,跨浏览器等问题,HTML5存储出来了,把这些都统一了,如下图:

    2011052411382518

    HTML5本地存储  

           HTML5有几种存储方式:本地存储(localstorage和sessionstorage), 应用程序缓存(Application Cache) , IndexedDB和Web SQL。这里主要介绍本地存储(localstorage和sessionstorage)!

    360截图20150415160156584

    首先看一下浏览器支持度怎么样:

    360截图20150415160012170

    上面这张图可能不是很直观,总结就是 IE8.0+,Firefox3.5+,Safari4.0+,Chrome4.0+,Opera10.5+,

    iPhone2.0+,Android2.0+ 都支持。

    那么在使用本地存储之前就需要检测一下浏览器是否支持了:

          在HTML5中,本地存储是一个window的属性,包括localStorage和sessionStorage,从名字应该可以很清楚的辨认二者的区别,前者是一直存在本地的,后者只是伴随着session,窗口或浏览器一旦关闭就没了。二者用法完全相同,这里我们就以localStorage为例。

    if(window.localStorage){
        alert('This browser supports localStorage');
    }else{
        alert('This browser does NOT support localStorage');
    }

    以上就是用于检测当前浏览器是否支持本地存储。

    使用HTML5 Storage

          HTML5 Storage 基于键值对存储。你要存储的数据需要有一个名字作为键,然后你就可以使用这个键读取这个数据。这个键是一个字符串;数据则可以是 JavaScript 支持的任何数据类型,包括字符串、布尔值、整数和浮点数。但是,我们通常将数据作为字符串进行存储。HTML5 Storage 可以存储数组,json数据,图片,脚本,样式文件,当然,这些都需要转化成字符串再进行存储。

    OK,接下来就介绍一下localstorage API

    //以键值对形式存储,Key –> Value

    Key:表示你要存入的键名称,此名称可以随便命名,可以按照变量的意思来理解。

    Value:表示值,也就是你要存入Key中的值,可以按照变量赋值来理解。

    保存数据:localStorage.setItem(Key, value);

    读取数据:localStorage.getItem(Key);

    删除数据:localStorage.removeItem(Key);

    索引值:localStorage.key(0);

    清除所有数据:localStorage.clear();

    这里提供一个例子,来熟悉一下如何使用localStorage:

    <!DOCTYPE HTML>
    <html>
        <head>
            <meta charset="utf-8">
            <title>本地存储LocalStorage</title>
            <script type="text/javascript">
                    window.onload = function()
                    {
                            alert("当你关闭此页面或者关闭浏览器的时候,localStorage中保存的数据才会消失,也就是说重新打开此页面的时候,点击获取数据,可以取到数据。")
                            
                            //首先获得body中的3个input元素
                            var msg = document.getElementById("msg");
                            var getData = document.getElementById("getData");
                            var setData = document.getElementById("setData");
                            
                            setData.onclick = function()//存入数据
                            {
                                    if(msg.value)
                                    {
                                            localStorage.setItem("data", msg.value);
                                            alert("信息已保存到data字段中");
                                    }
                                    else
                                    {
                                            alert("信息不能为空");
                                    }
                            }
                            
                            getData.onclick = function()//获取数据
                            {
                                    var msg = localStorage.getItem("data");
                                    if(msg)
                                    {
                                            alert("data字段中的值为:" + msg);
                                    }
                                    else
                                    {
                                            alert("data字段无值!");
                                    }
                            }
                    }
            </script>
        </head>
        
        <body>
                <input id="msg" type="text"/>
            <input id="setData" type="button" value="保存数据"/>
            <input id="getData" type="button" value="获取数据"/>
        </body>
    </html>

    最后附上我通过视频教程学习HTML5 Storage做的一点笔记:

    注意事项:

    使用前要判断浏览器是否支持

    写数据时候,需要异常处理,避免超出容量抛错

    避免把敏感的信息存入localstorage

    key的唯一性

    使用限制:

    存储更新策略,过期控制

    子域名之间不能共享存储数据

    超出存储大小之后如何存储(LRU,FIFO)

    server端如何取到

    使用场景:

    利用本地数据,减少网络传输

    弱网络环境下,高延迟,低带宽,尽量把数据本地化

    参考资料:

    http://www.iefans.net/html5-bendi-cunchu/

    http://www.cnblogs.com/xiaowei0705/archive/2011/04/19/2021372.html

    http://www.w3cfuns.com/article-5592538-1-1.html

  • 相关阅读:
    LeetCode 137. Single Number II
    LeetCode 16. 3Sum Closest
    LeetCode 18. 4Sum
    LeetCode 15. 3Sum
    LeetCode 166. Fraction to Recurring Decimal
    LeetCode Anagrams
    Java: Difference between ArrayList and LinkedList
    LeetCode 242. Valid Anagram
    LeetCode 204. Count Primes
    Java Class Variable/Static Variable
  • 原文地址:https://www.cnblogs.com/jr1993/p/4429138.html
Copyright © 2011-2022 走看看