`
赵彦枝
  • 浏览: 49115 次
  • 性别: Icon_minigender_2
  • 来自: 河北
社区版块
存档分类
最新评论

使用JS进行本地存取数据

 
阅读更多

         本地存储是一个window的属性,包括localStorage和sessionStorage,从名字应该可以很清楚的辨认二者的区别,前者是一直存在本地的,除非清空本地的数据,后者只是伴随着session,窗口一旦关闭就没了。两者的用法完全一样。存储数据的方法就是直接给window.localStorage添加一个属性,例如:window.localStorage.a 或者 window.localStorage["a"]。它的读取、写、删除操作方法很简单,是以键值对的方式存在的,例如:

localStorage.a = 1;//设置a为"3"
localStorage["a"] = "nihao";//a的新值会覆盖上面的值;
localStorage.setItem("b","hello");//设置b为"hello";
var a1 = localStorage["a"];//获取a的值
var a2 = localStorage.a;//获取a的值
var b = localStorage.getItem("b");//获取b的值
localStorage.removeItem("c");//清除c的值

 

           最常使用的是getItem()和setItem()方法,清除键值对使用removeItem()。如果希望一次性清除所有的键值对,使用clear()。另外HTML5还提供了一个key()方法,可以在不知道有哪些键值的时候使用,如下:

 

var storage = window.localStorage;
function showStorage(){
 for(var i=0;i<storage.length;i++){
   //key(i)获得相应的键,再用getItem()方法获得对应的值
   document.write(storage.key(i)+ " : " + storage.getItem(storage.key(i)) + "<br>");
    }
 }
   

          需要注意的是,HTML5本地存储只能存字符串,任何格式存储的时候都会被自动转为字符串,所以在存和读取的时候,需要自己进行类型的转换,目前javascript使用非常多的json格式,可以直接调用JSON.stringify()将其转为字符串。读取出来后调用JSON.parse()将字符串转为json格式,如下所示:

 

 

//本地存取对象
var  cartInfo={classification: "饮料",name: "可口可乐", price: "3", unit: "瓶"};
localStorage.setItem("data",JSON.stringify(cartInfo)); //  往本地存 cartInfo这个对象
var cartInfo=JSON.parse(localStorage.getItem("data"));//从本地取出 cartInfo这个对象
//本地也可以存取元素为对象的数组,和上面的方法一样
var cartList =[
               {classification: "饮料",name: "可口可乐", price: "3", unit:“瓶”},
               {classification: "饮料",name: "雪碧", price : "3",   unit:“瓶”},
               {classification: "水果", name: "苹果", price : "5.5", unit: "斤"},
               {classification: "水果", name: "荔枝",  price: "15",   unit: "斤"},
               {classification: "生活用品",name: "电池", price : "2", unit:“个”},
               {classification: "食品", name: "方便面",  price: "4.5", unit: "袋"},
               ];
 localStorage.setItem("cartList",JSON.stringify(cartList)); //  往本地存cartList这个数组
 cartList=JSON.parse(localStorage.getItem("cartList"));  //从本地取出 cartList这个数组

 

 

 

 

分享到:
评论

相关推荐

    extjs中本地照片预览、blob数据在oracle中存取

    此压缩包中完全能实现的功能是在extjs中让本地照片预览,并且将地址传递给java后台,将图片文件以blob的形式存储到oracle数据库,并且可以默认将数据库中的数据第一次加载在预览框里(也就是从数据库中读出blob数据...

    绝对好用!extjs中本地照片预览、blob数据在oracle中存取.zip

    此压缩包中完全能实现的功能是在extjs中让本地照片预览,并且将地址传递给java后台,将图片文件以blob的形式存储到oracle数据库,并且可以默认将数据库中的数据第一次加载在预览框里(也就是从数据库中读出blob数据...

    Java-图片BLOB的存取DEMO

    直接将结果select查询出来再update行不通,所以先将图片从库里导到本地,然后在从本地拿数据进行更新操作,根据ImgID进行update操作 ; jdbc参数放到db.properties里(有工具类) WEB方式未实现,后期自行研究(可...

    yux-storage:yux-storage 是一个基于 HTML5 IndexedDB 封装的 Web 本地数据离线存储库

    异步操作,在进行大量数据存取时不会阻塞应用程序。 适用场景 适用于复杂对象、经常需要序列化处理的数据操作,否则使用 localStorage 更加方便 快速开始 安装 直接在 获取 yux-storage.js (推荐) [removed]...

    Android代码-安卓H5交互,独立规则

    js就按照这个方式去像1,中一样去调用安卓本地方法。 import android.app.Activity; /** Created by TL on 2016/6/1. */ public abstract class ActionService { protected Activity activity; public Action...

    实现JavaScript高性能的数据存储

    1.JavaScript中四种基本数据存取位置:字面量,本地变量,数组元素,对象成员。 一般来说:[字面量,局部变量]运行速度&gt;[数组,对象成员] 2.内部属性包含了一个函数被创建的作用域中对象的集合。这个集合被称为作用域...

    JsScript VbScript脚本解析控件

    9.可以利用xmlhttp实现asp、jsp等页面的数据的存取解析,轻松访问第三方的数据 10.利用强大的VBScript脚本技术可以实现数据库接口,轻松将程序中的变量写入第三方的数据库中 如果您正在被流程设计中繁杂的逻辑判断...

    java面试宝典

    144、当我重编译我的JSP使用的一个类后,为什么JVM继续使用我的老CLASS? 36 145、与之间的差别? 36 146、JSP的缺点? 36 148、如何实现JSP的国际化? 36 150、如何在JSP中包括绝对路径文件? 使用URLConnection...

    基于 JavaEE 的快速开发框架 Tephra-JavaEE

    提供全冗余方式的缓存,自动在每个节点间同步缓存数据,而每个节点都仅从本地内存中获取缓存数据,从而提供高效的执行效率,并且当部分节点宕机时仍旧能正常提供服务。当然,也允许使用Redis提供统一的中心节点缓存...

    php网络开发完全手册

    3.2.7 使用函数进行数据类型的强制 3.2.7 转换 57 3.3 小结 57 第4章 函数处理与数据引用 58 4.1 函数的定义与使用 58 4.1.1 函数的调用 58 4.1.2 用户自定义函数的编写 58 4.2 PHP常用函数 59 4.2.1 获得日期时间...

    LNMP/Nginx 虚拟主机面板 AMH v5.0.zip

    11、改进面板异步存取数据,提高面板响应速度。 12、面板增加桌面程序支持,同时可扩展桌面程序。 13、改进兼容 Centos、Debian、Ubuntu 所有发行版本安装,包括最新的 Centos7 与 Debian7 系统。 14、面板增加...

    Delphi6分布式开发

    10. 2.1 delphi 6中无状态的中间层数据存取 10. 2.2 多层体系结构下的事务 10.2.3 一个基本的midas例子 10.2.4 公文包模式介绍以及具体例子 10.2.5 datapooler技术的例子 10. 3 在 midas中使用 activex...

    PhoneGap Beginner’s Guide

    第8章:相机数据存取和文件191 采取行动的时间 - 用相机的API 191的Hello World 浏览器是不是模拟器或设备198 图像来源199 其他选项199 当我们终于得到一个形象是什么? 200 时间F或行动 - 获取的文件路径显示200 这...

    ABP(2.02)框架相关Demo代码以及报错处理和中文说明手册

    我们在开发企业WEB应用程序时都有一些类似的需求,例如:都需要登录页面、用户/角色管理、权限验证、数据有效性验证、多语言/本地化等等。一个高品质的大型软件都会运用一些最佳实践,例如分层体系结构、领域驱动...

    Tcl_TK编程权威指南pdf

    该函数库实现了基本的解释器,它有一套实现变量、流程控制和过程的核心脚本命令,而且还有一组用来存取操作系统服务以运行其他程序、存取文件系统和使用网络套接字的命令。Tcl和Tk提供了一台可以在UNIX、Windows和...

    基于JavaEE的快速开发框架

    提供全冗余方式的缓存,自动在每个节点间同步缓存数据,而每个节点都仅从本地内存中获取缓存数据,从而提供高效的执行效率,并且当部分节点宕机时仍旧能正常提供服务。当然,也允许使用Redis提供统一的中心节点缓存...

    千方百计笔试题大全

    144、当我重编译我的JSP使用的一个类后,为什么JVM继续使用我的老CLASS? 36 145、 file="abc.jsp"%&gt;与 page="abc.jsp"/&gt;之间的差别? 36 146、JSP的缺点? 36 148、如何实现JSP的国际化? 36 150、如何在JSP中...

    计算机应用技术(实用手册)

    4.格式之间的转换,使用winavi进行转换 32 5.常用的快捷键,使用快捷可以帮助我节约时间。 33 6.开机常按F8可以进入安全模式或是带DOS命令的安全模式。 33 第六章GHOST的备份与恢复 34 第七章 综合应用 44 一....

    精易模块[源码] V5.15

    2、添加“文本_朗读”是否使用百度语音引擎参数,为空时默认使用微软语音引擎。 3、改善“文本_加密”与“文本_解密”去除原来算法,改用微软基础加解密API。 4、修复“网页_打印”,无效的BUG,感谢易友【@nameyypx...

Global site tag (gtag.js) - Google Analytics