1.需求背景:当用户在页面上添加一行一行的数据时,突然发现网络断掉了,页面上编辑的数据没法保存进数据库,所以需要一个本地端的临时保存功能,以便在网络通畅后重新加载出来!

2.解决方案:

结合网上搜刮,考虑到了这几种方式:1)采用cookie; 2)看能不能采用浏览器的页面缓存来模拟 3)使用html5

1)cookie使用(做测试是直接用浏览器打开没有效果,需要放到站点下)

所有浏览器都支持,所以不需要去考虑兼容性的问题;

浏览器对于同一domain最多支持20个左右cookie,每个cookie的长度也有限制,超长部分就会被截掉

过期的限制:在cookie的生命周期内有效,过期就会被清掉

还有就是每次对服务器的请求cookie都会附带上去增加了网络带宽

鉴于以上几点考虑,并且项目中希望以文件形式存储,不予考虑!

cookie存储操作示例:

  1. function setCookie() {
  2. var value = $('#data').val();
  3. if (value != '' && $.trim(value) != '') {
  4. var expireDate = new Date();
  5. expireDate.setTime(expireDate.getTime() + 30 * 24 * 3600 * 1000);
  6. document.cookie = "data=" + escape(value) + ("; expires=" + expireDate.toGMTString());
  7.  
  8. } else {
  9. alert('请输入要存储的数据!');
  10. }
  11. }
  12. function getCookie() {
  13. if (document.cookie.length > 0) {
  14. var startIndex = 5;
  15. var endIndex = document.cookie.indexOf(";", 0);
  16. var data = "";
  17. if (endIndex != -1) {
  18. data = unescape(document.cookie.substring(startIndex, endIndex));
  19.  
  20. } else {
  21. data = unescape(document.cookie.substring(startIndex, document.cookie.length));
  22. }
  23. $('#data-display').html(data);
  24. }
  25. }

 2).localStorage

html5本地存储分为两种,一是key-value对的形式存储,一种是DateBase存储;

1.key-value本地存储有sessionStorage和localStorage两种

sessionStorage:会话存储,生命期从进入网站开始,从关闭网站后结束

localStorage:本地存储,即使关闭浏览器,再次打开时同样能够读取到存储的数据,这也是其与sessionStorage的区别

示例:

  1. window.localStorage.setItem('name','istone');
  2. window.localStorage.getItem('name');

  2.html5本地数据库,提供了一套API来操作

  1. var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024);
  2. var msg;
  3.  
  4. db.transaction(function (tx) {
  5. tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id unique, log)');
  6. tx.executeSql('INSERT INTO LOGS (id, log) VALUES (1, "foobar")');
  7. tx.executeSql('INSERT INTO LOGS (id, log) VALUES (2, "logmsg")');
  8. msg = '<p>Log message created and row inserted.</p>';
  9. document.querySelector('#status').innerHTML = msg;
  10. });
  11.  
  12. db.transaction(function (tx) {
  13. tx.executeSql('SELECT * FROM LOGS', [], function (tx, results) {
  14. var len = results.rows.length, i;
  15. msg = "<p>Found rows: " + len + "</p>";
  16. document.querySelector('#status').innerHTML += msg;
  17.  
  18. for (i = 0; i < len; i++){
  19. msg = "<p><b>" + results.rows.item(i).log + "</b></p>";
  20. document.querySelector('#status').innerHTML += msg;
  21. }
  22. }, null);
  23. });

  浏览器支持情况

3)h5File API

对于页面数据的保存,采用js库将数据json化,如:JSON.stringify(),IE的数据保存网上搜到是调用浏览器'另存为'的功能来保存成txt,而对于chrome的数据保存调用html5的API接口blob封装数据提供给a标签的href,文件名提供给download

  1. function saveDraftForIE(fileName,content) {
  2. var win = window.open('', '', 'top=10000,left=10000');
  3. win.document.write(content);
  4. win.document.execCommand('SaveAs', '', fileName)
  5. win.close();
  6. }
  7. function saveDraftForChrome(fileName,content) {
  8. function fake_click(obj) {
  9. var ev = document.createEvent("MouseEvents");
  10. ev.initMouseEvent(
  11. "click", true, false, window, 0, 0, 0, 0, 0
  12. , false, false, false, false, 0, null
  13. );
  14. obj.dispatchEvent(ev);
  15. }
  16. var urlObject = window.URL || window.webkitURL || window;
  17. var export_blob = new Blob([content]);
  18. var save_link = document.createElementNS("http://www.w3.org/1999/xhtml", "a")
  19. save_link.href = urlObject.createObjectURL(export_blob);
  20. save_link.download = fileName;
  21. fake_click(save_link);
  22. }

  对于本地文件的读取,采用html5 fileAPI:FileReader,通过readAsText方法读取到本地json串,JSON.parser()转回去.

Web端本地存储的更多相关文章

  1. H5新增的Web Storage本地存储

    html5中的Web Storage包括了两种存储方式:sessionStorage和localStorage. sessionStorage用于本地存储一个会话(session)中的数据,这些数据只 ...

  2. web端本地与服务端时间校验

    当前校验逻辑: 本地和服务端的时间校验绑定在一个通用请求上,这个请求每七分钟会到服务端请求一次,本地拿到服务器时间后,计算请求服务器来回的时间,最后得出与服务器时间的差值,然后每次new Date() ...

  3. HTML5本地存储 Web Storage

    Web Storage基本介绍 HTML5 定义了本地存储规范 Web Storage , 提供了两种存储类型 API  sessionStorage 和 localStorage,二者的差异主要是数 ...

  4. web前端实现本地存储

    当我们在提及web前端本地存储的时候,首先需要介绍一下本地化存储的概念和历史.本地化存储从来不是一个新奇的概念,因为web应用程序一直在追求的就是媲美甚至超越桌面应用程序.但是桌面应用程序一直优于we ...

  5. H5本地存储详细使用教程(localStorage + JSON数据存储应用框架)

    一.Web Storage教程 1.概述: 对于Web Storage来说,实际上是Cookies存储的进化版.如果了解Cookie的人几乎一看Web Storage就会用,如果你从来没用过没了解过C ...

  6. HTML5 学习笔记(三)——本地存储(LocalStorage、SessionStorage、Web SQL Database)

    一.HTML4客户端存储 B/S架构的应用大量的信息存储在服务器端,客户端通过请求响应的方式从服务器获得数据,这样集中存储也会给服务器带来相应的压力,有些数据可以直接存储在客户端,传统的Web技术中会 ...

  7. web 本地存储 (localStorage、sessionStorage)

    web 本地存储 (localStorage.sessionStorage,cookie) localStorage(长期储存):即使关闭浏览器数据也不会删除,除非使用localStorage.cle ...

  8. HTML5开发学习:本地存储Web Sql Database

       Web Sql Database,中文翻译作"本地数据库",是随着HTML5规范加入的在浏览器端运行的轻量级数据库.    在HTML5中,大大丰富了客户端本地可以存储的内容 ...

  9. 腾讯云点播视频存储(Web端视频上传)

    官方文档 前言 所谓视频上传,是指开发者或其用户将视频文件上传到点播的视频存储中,以便进行视频处理.分发等. 一.简介 腾讯云点播支持如下几种视频上传方式: 控制台上传:在点播控制台上进行操作,将本地 ...

随机推荐

  1. 2015 Multi-University Training Contest 4 hdu 5334 Virtual Participation

    Virtual Participation Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Ot ...

  2. 洛谷 P1617 爱与愁的一千个伤心的理由

    P1617 爱与愁的一千个伤心的理由 题目背景 (本道题目隐藏了两首歌名,找找看哪~~~) <爱与愁的故事第一弹·heartache>第二章. 经历了心痛后,爱与愁大神不行了. 题目描述 ...

  3. 洛谷 P3507 [POI2010]GRA-The Minima Game

    P3507 [POI2010]GRA-The Minima Game 题目描述 Alice and Bob learned the minima game, which they like very ...

  4. Xdoclet + Ant自己主动生成Hibernate配置文件

    在使用Hibernate的时候,过多的Hibernate配置文件是一个让人头疼的问题. 近期接触了Xdoclet这个工具. 它实际上就是一个自己主动代码生成的工具.Xdoclet不能单独执行,必须搭配 ...

  5. 使用Modernizr检测支持CSS3

    使用Modernizr检测支持CSS3 如果支持某个属性,会增加一个class,名字就是该属性: 不支持,名字是no-某属性 还提供了一个全局Modernizr对象,使用如下: <script ...

  6. Go语言Slice操作.

    1.基本使用方法: a = append(a, b...) 比如:list = appened(list,[]int{1,2,3,4}...) 能够用来合并两个列表. 不用这样了 :list := m ...

  7. JavaWeb错误处理集锦

    一:起因 (1)自己接下来想走算法的路子,打算把十大算法和数学模型学习一下,算是给自己之前 JavaWeb 的一个总结: (2)记得Java算是第一个比較上手的语言了,更是用JavaWeb走过了非常长 ...

  8. legend---十一、thinkphp事务中if($ans1&&$ans2){}else{}方式和try{}catch{}方式事务操作的区别在哪里

    legend---十一.thinkphp事务中if($ans1&&$ans2){}else{}方式和try{}catch{}方式事务操作的区别在哪里 一.总结 一句话总结:执行的条件其 ...

  9. rsync来传输文件(可断点续传)

    scp传文件的话如果出错就得重新来过, 用rsync可以实现断点上传的功能   大概就是这样用:  rsync -P --rsh=ssh home.tar 192.168.205.34:/home/h ...

  10. SQL 的stuff函数

    1.作用 删除指定长度的字符,并在指定的起点处插入另一组字符. 2.语法 STUFF ( character_expression , start , length ,character_expres ...