• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    HTML5 WebStorage(HTML5本地存储技术)

    WebStorage是HTML5中本地存储的解决方案之一,在HTML5的WebStorage概念引入之前除去IE User Data、Flash Cookie、Google Gears等看名字就不靠谱的解决方案,浏览器兼容的本地存储方案只有使用cookie。有同学可能会问,既然有了cookie本地存储,为什么还要引入WebStorage的概念?

    Cookie肿么了

    cookie的缺陷是非常明显的

    1. 数据大小:作为存储容器,cookie的大小限制在4KB左右这是非常坑爹的,尤其对于现在复杂的业务逻辑需求,4KB的容量除了存储一些配置字段还简单单值信息,对于绝大部分开发者来说真的不知指望什么了。
    2. 安全性问题:由于在HTTP请求中的cookie是明文传递的(HTTPS不是),带来的安全性问题还是很大的。
    3. 网络负担:我们知道cookie会被附加在每个HTTP请求中,在HttpRequest 和HttpResponse的header中都是要被传输的,所以无形中增加了一些不必要的流量损失。

    WebStorage

    WebStorage是HTML新增的本地存储解决方案之一,但并不是为了取代cookie而制定的标准,cookie作为HTTP协议的一部分用来处理客户端和服务器通信是不可或缺的,session正是依赖于实现的客户端状态保持。WebStorage的意图在于解决本来不应该cookie做,却不得不用cookie的本地存储。
    WebStorage提供两种类型的API:localStorage和sessionStorage,两者的区别看名字就有大概了解,localStorage在本地永久性存储数据,除非显式将其删除或清空,sessionStorage存储的数据只在会话期间有效,关闭浏览器则自动删除。两个对象都有共同的API。

    复制代码 代码如下:

    interface Storage {
      readonly attribute unsigned long length;
      DOMString? key(unsigned long index);
      getter DOMString getItem(DOMString key);
      setter creator void setItem(DOMString key, DOMString value);
      deleter void removeItem(DOMString key);
      void clear();
    };

    1、length:唯一的属性,只读,用来获取storage内的键值对数量。
    2、key:根据index获取storage的键名
    3、getItem:根据key获取storage内的对应value
    4、setItem:为storage内添加键值对
    5、removeItem:根据键名,删除键值对
    6、clear:清空storage对象

    WebStorage如何使用

    在实现了WebStorage的浏览器中,页面有两个全局的对象localStorage和sessionStorage

    以localStorage为例,看一段简单的操作代码

    复制代码 代码如下:

    var ls=localStorage;
                console.log(ls.length);//0
                ls.setItem('name','Byron');
                ls.setItem('age','24');
                console.log(ls.length);//2

                //遍历localStorage
                for(var i=0;ils.length;i++){
                    /*
                        age : 24
                        name : Byron
                    */
                    var key=ls.key(i);
                    console.log(key+' : '+ls.getItem(key));
                }

                ls.removeItem('age');

               
                for(var i=0;ils.length;i++){
                    /*
                        name : Byron
                    */
                    var key=ls.key(i);
                    console.log(key+' : '+ls.getItem(key));
                }
                ls.clear();//0
                console.log(ls.length);

    事件

    同时HTML5规定了一个storage事件,在WebStorage发生变化的时候触发,可以用此监视不同页面对storage的修改

    复制代码 代码如下:

    interface StorageEvent : Event {
      readonly attribute DOMString key;
      readonly attribute DOMString? oldValue;
      readonly attribute DOMString? newValue;
      readonly attribute DOMString url;
      readonly attribute Storage? storageArea;
    };

    1、key:键值对的键
    2、oldValue:修改之前的value
    3、newValue:修改之后的value
    4、url:触发改动的页面url
    5、StorageArea:发生改变的Storage

    在index.php中定义

    复制代码 代码如下:

    a href="test.php" target="_blank">Test/a>

    复制代码 代码如下:

    window.addEventListener('storage',function(e){
                    console.log(e.key+' is changed form '+e.oldValue+' to '+e.newValue+' by '+e.url );
                    console.log(e.storageArea ==localStorage);
                },false);

                localStorage.setItem('userName','Byron');

    test.php

    复制代码 代码如下:

    localStorage.setItem('userName','Casper');

    在index.php页面点击链接访问test.php时可以看到index.php的控制台输出log:
    userName is changed form Byron to Casper by http://localhost/test.php
    true

    为什么比cookie好

    1. 从容量上讲WebStorage一般浏览器提供5M的存储空间,用来存储视频、图片神马的不够,但对于绝大部分操作足矣
    2.安全性上WebStorage并不作为HTTP header发送的浏览器,所以相对安全
    3.从流量上讲,因为WebStorage不传送到服务器,所以不必要的流量可以节省,这样对于高频次访问或者针对手机移动设备的网页还是很不错的。
    这并不意味着WebStorage可以取代cookie,而是有了WebStorage后cookie能只做它应该做的事情了——作为客户端与服务器交互的通道,保持客户端状态。所以仅仅作为本地存储解决方案WebStorage是优于cookie的。

    需要注意的地方

    1.浏览器兼容性,这个几乎是所有HTML5新特性中最容易实施的了,因为IE8+的浏览器都支持,在IE7、IE6中可以使用IE User Data实现。

     2. 由于localStorage和sessionStorage都是对象,所以我饿每年也可以通过”.key”或”[key]”的方式获取、修改键值对,但不推荐这么做 。
    复制代码 代码如下:

    localStorage.userName='Frank';
    console.log(localStorage['userName']);

    3.虽然localStorage存储在本地,但不同的浏览器存储存储数据是独立的,所以在Chrome上存储的localStorage在FireFox上是获取不到的。
    4. localStorage和sessionStorage只能存储字符串类型,对于复杂的对象可以使用ECMAScript提供的JSON对象的stringify和parse来处理,低版本IE可以使用json2.js
    5.除了控制台,Chrome还为本地存储提供了非常直观的显示方式,调试的时候很方便

    您可能感兴趣的文章:
    • Javascript怎样使用SessionStorage和LocalStorage
    • 如何在JavaScript中使用localStorage详情
    • Vue基于localStorage存储信息代码实例
    • vue 使用localstorage实现面包屑的操作
    • JS+HTML5本地存储Localstorage实现注册登录及验证功能示例
    • 使用vuex存储用户信息到localStorage的实例
    • JavaScript学习教程之cookie与webstorage
    • 详解vue中localStorage的使用方法
    • vue 界面刷新数据被清除 localStorage的使用详解
    • 浅谈Web Storage API的使用
    上一篇:浅谈href=#与href=javascript:void(0)的区别
    下一篇:html的基本使用(HTML标签解释)
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    HTML5 WebStorage(HTML5本地存储技术) HTML5,WebStorage,本地,存储,