1、sessionStorage

特点:关闭浏览器(或标签页)后数据就不存在了。但刷新页面或使用“前进”、“后退按钮”后sessionStorage仍然存在;

   sessionStorage每个窗口的值都是独立的(每个窗口都有自己的数据),它的数据会随着窗口的关闭而消失,窗口间的sessionStorage也是不可以共享的;

   储存大小4M。

方法:setItem(key, value)  getItem(key)  removeItem(key)。

2、localStorage

特点:localStorage把只把数据存储在了客户端使用,不会发送的服务器上(除非你故意这样做)

   而且对于某一个域下来说,local storage是共享的(多个窗口共享一个“数据库”)

   localStorage用于持久化的本地存储,除非主动删除数据,否则数据是永远不会过期的。

方法类似于sessionStorage

应用:

 (function(owner) {
     /**
      * 用户登录
      **/
     owner.login = function(loginInfo, callback) {
         callback = callback || $.noop;
         loginInfo = loginInfo || {};
         loginInfo.account = loginInfo.account || '';
         loginInfo.password = loginInfo.password || '';
         if (loginInfo.account.length < 5) {
             return callback('账号最短为 5 个字符');
         }
         if (loginInfo.password.length < 6) {
             return callback('密码最短为 6 个字符');
         }
         var users = JSON.parse(localStorage.getItem('$users') || '[]');
         var authed = users.some(function(user) {
             return loginInfo.account == user.account && loginInfo.password == user.password;
         });
         if (authed) {
             return owner.createState(loginInfo.account, callback);
         } else {
             return callback('用户名或密码错误');
         }
     };

     owner.createState = function(name, callback) {
         var state = owner.getState();
         state.account = name;
         state.token = "token123456789";//状态码
         owner.setState(state);
         return callback();
     };

     /**
      * 新用户注册
      **/
     owner.reg = function(regInfo, callback) {
         callback = callback || $.noop;
         regInfo = regInfo || {};
         regInfo.account = regInfo.account || '';
         regInfo.password = regInfo.password || '';
         if (regInfo.account.length < 5) {
             return callback('用户名最短需要 5 个字符');
         }
         if (regInfo.password.length < 6) {
             return callback('密码最短需要 6 个字符');
         }
         if (!checkEmail(regInfo.email)) {
             return callback('邮箱地址不合法');
         }
         var users = JSON.parse(localStorage.getItem('$users') || '[]');
         users.push(regInfo);
         localStorage.setItem('$users', JSON.stringify(users));
         return callback();
     };

     /**
      * 获取当前状态
      **/
     owner.getState = function() {
         var stateText = localStorage.getItem('$state') || "{}";
         return JSON.parse(stateText);
     };

     /**
      * 设置当前状态
      **/
     owner.setState = function(state) {
         state = state || {};
         localStorage.setItem('$state', JSON.stringify(state));
         //var settings = owner.getSettings();
         //settings.gestures = '';
         //owner.setSettings(settings);
     };

     var checkEmail = function(email) {
         email = email || '';
         return (email.length > 3 && email.indexOf('@') > -1);
     };

     /**
      * 找回密码
      **/
     owner.forgetPassword = function(email, callback) {
         callback = callback || $.noop;
         if (!checkEmail(email)) {
             return callback('邮箱地址不合法');
         }
         return callback(null, '新的随机密码已经发送到您的邮箱,请查收邮件。');
     };

     /**
      * 获取应用本地配置
      **/
     owner.setSettings = function(settings) {
         settings = settings || {};
         localStorage.setItem('$settings', JSON.stringify(settings));
     }

     /**
      * 设置应用本地配置
      **/
     owner.getSettings = function() {
             var settingsText = localStorage.getItem('$settings') || "{}";
             return JSON.parse(settingsText);
         }

 }(window.app = {}));

上述代码可以应用于H5 app的用户登录。不断的通过localStorage的setItem与getItem方法来存储用户的登陆信息。

 //登陆
 var loginInfo = {
     account: user.value,
     password: password.value
 };
 app.login(loginInfo, function(err) {
     if (err) {
         plus.nativeUI.toast(err);
         return;
     }
    //上传服务器
 });        

HTML5储存的更多相关文章

  1. html5储存篇(二)

    indexedDB   相对于html5 中提到 web SQL Database,w3c已经明确声明放弃对其的继续支持,开始支持新的客户端数据库 indexedDB ,indexedDB 是一种no ...

  2. html5 说明

    # 客户端储存历程 远古时期 cookies的用法和缺陷 userdata   HTML5时代 localstorage application cache 离线缓存 indexedeDB 客户端数据 ...

  3. Vue+localstrong登录注册,并保持登录状态

    在router.js中添加meta区分 比如登录注册页面,不需要登录即可进入,那么我们把meta中的isLogin标志设置为false { //登录 path: '/login', component ...

  4. Vue登录注册,并保持登录状态

    关于vue登录注册,并保持登录状态,是vue玩家必经之路,网上也有很多的解决方法,但是有一些太过于复杂,新手可能会看的一脸懵逼,现在给大家介绍一种我自己写项目在用而且并不难理解的一种方法. 项目中有一 ...

  5. <<< html5本地储存

    类似与Cookies,但由于Cookies储存量太小,大小也只有4-5KB的样子,html5的本地储存能存5M大小的数据 html5本地储存属性有,localStorage和sessionStorag ...

  6. 阿伦学习html5 之 Local Storage (本地储存)

    一.浏览器存储的发展历程 本地存储解决方案很多,比如Flash SharedObject.Google Gears.Cookie.DOM Storage.User Data.window.name.S ...

  7. HTML5 的web储存: localStorage & sessionStorage

    早期的浏览器使用cookie储存,HTML5新增web储存,包括:localStorage 和 sessiongStorage; localStorage:可以永久储存: sessionStorage ...

  8. HTML5的离线储存

    在用户没有与因特网连接时,可以正常访问站点或应用,在用户与因特网连接时,更新用户机器上的缓存文件.        原理:HTML5的离线存储是基于一个新建的.appcache文件的缓存机制(不是存储技 ...

  9. 转 html5离线储存,application cache,manifest使用体验

    html5离线应用application cache 最近在APP里新增一个论坛模块,为了快速地完成,决定将整个论坛模块做成WEB APP,WEB APP最致命的就是用户体验问题,页面跳转和过多的请求 ...

随机推荐

  1. hdoj 2063 过山车【匈牙利算法+邻接矩阵or邻接表】

    过山车 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  2. iOS 更好用的打Log方式-显示文件名、行数

    单纯的NSLog方式打出的Log没有显示打印语句所在的文件名和行数,下面这种做法会很实用: #ifdef DEBUG # define DLog(fmt, ...) NSLog((@"%s ...

  3. iOS socket原理及连接过程详解

    连接过程图解(度娘的拿过来用)

  4. View,viewgroup,viewstub总结

    :first-child { margin-top: 0; } blockquote > :last-child { margin-bottom: 0; } img { border: 0; m ...

  5. Sublime_text3怎么运行php代码

    开发神奇sublime写代码真的好爽,之前听说是神器,但是没去用,觉得用eclipse写php代码,用dw写html够用了,用了一下sublime,哈哈,爽爆了. 除了写前端代码外,还需要写php代码 ...

  6. 【iOS-Android开发对照】 之 APP入口

    [iOS-Android开发对照]之 APP入口 [图片 Android vs iOS] 提纲 对照分析iOS,Android的入口, iOS,Android的界面单元 为什么要有那样的生命周期 继承 ...

  7. Android注解支持(Support Annotations)

    注解支持(Support Annotations) Android support library从19.1版本开始引入了一个新的注解库,它包含很多有用的元注解,你能用它们修饰你的代码,帮助你发现bu ...

  8. android智能天气闹钟应用开发经过

    开发这个应用的初衷是这样产生滴,和我一块租房的同学每天早上都是骑单车上班,所以手机闹钟就会定一个刚好适合骑车的起床时间点.但是呢,有一天早上起床以后发现外面下挺大雨,肯定是不能骑车去上班了,于是就只好 ...

  9. android注解使用详解(图文)

    在使用Java的SSH框架的时候,一直在感叹注解真是方便啊,关于注解的原理,大家可以参考我的另一片文章Java注解详解.最近有时间研究了android注解的使用,今天与大家分享一下. android中 ...

  10. Mybatis下配置调用Oracle自定义函数返回的游标结果集

    在ibatis和Mybatis对存储过程和函数函数的调用的配置Xml是不一样的,以下是针对Mybatis 3.2的环境进行操作的. 第一步配置Mapper的xml内容 <mapper names ...