位置: 编程技术 - 正文

详解JavaScript中localStorage使用要点(js中的)

编辑:rootadmin

推荐整理分享详解JavaScript中localStorage使用要点(js中的),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js中的,javascript的,js中loop,javascriptz,javascript:;怎么解决,js中loop,js中loop,javascript definitive guide,内容如对您有帮助,希望把文章链接给更多的朋友!

localStorage主要用来替代cookie,解决cookie(可参考cookie使用要点)读写困难、容量有限的问题。

localStorage有以下几个特点

1.localStorage是一个普通对象,任何对象的操作都适用。

2.localStorage对象的属性值只能是字符串。

  这个需要特别注意了,假设我们要保存一个对象到localStorage中,可以使用拼接的方式。如

  当然也可以借助JSON类,将对象转换成字符串保存,然后在取出来的时候将json字符串转换成真正可用的json对象格式

3.localStorage支持的默认空间大小为5M,现代浏览器支持良好

  借用xiaowei的HTML5 LocalStorage 本地存储的切图

  积木网提醒大家需要注意的是在手机上使用的时候需要后台开辟内存空间支持才行。

  "QUOTA_EXCEEDED_ERR”"是一个异常,如果你使用的存储容量超过了限度(5M)就会报这个异常

4.localStorage本身带有方法有

  添加键值对:localStorage.setItem(key,value)

  获取键值:localStorage.getItem(key)

  删除键值对:localStorage.removeItem(key)。

  清除所有键值对:localStorage.clear()。

  获取localStorage的属性名称(键名称):localStorage.key(index)。

还有一个和普通对象不一样的属性length:

  获取localStorage中保存的键值对的数量:localStorage.length。

  下面这个例子用来获取localStorage的键值对

  本着相信原生方法的原则应尽量使用原生的方法来操作localStorage。但是在iPhone/iPad上有时调用setItem()时会出现诡异的QUOTA_EXCEEDED_ERR错误。解决方法是在setItem之前先removeItem()。所以从这个兼容问题来看,貌似使用对象添加/删除键值对更方便一些,兼容也更强一些。

5.localStorage事件

   localStorage的storage事件,在存储事件的处理函数中是不能取消这个存储动作的。

详解JavaScript中localStorage使用要点(js中的)

  存储事件只是浏览器在localStorage数据变化发生之后给你的一个通知。注意这里的的条件是数据真的发生了变化。也就是说,如果当前的存储区域是空的,你再去调用clear()是不会触发事件的。或者你通过setItem()来设置一个与现有值相同的值,事件也是不会触发的。当存储区域发生改变时就会被触发,这其中包含许多有用的属性:

&#;storageArea: 表示存储类型(Session或Local)&#;key:发生改变项的key&#;oldValue: key的原值&#;newValue: key的新值&#;url*: key改变发生的URL

  注意: url 属性早期的规范中为uri属性。有些浏览器发布较早,没有包含这一变更。为兼容性考虑,使用url属性前,你应该先检查它是否存在,如果没有url属性,则应该使用uri属性

  PS:在firefox和chrome中存储和读取都是正常的, 但是对storage事件的触发似乎有点问题,chrome修改localStorage能触发本页面的storage事件,Firefox 自身页面修改storage后没有触发window的storage事件, 但是同时访问A.html和B.html, 在A页面中进行 setItem能触发B页面中window的storage事件, 同样的在B页面中进行setItem能触发A页面中window的storage事件. 在IE9中, 页面自身的设值能触发当前页面的storage事件,同样当前页面的设值能触发同一”起源”下其他页面window的storage事件,这看起来似乎更让人想的通些.实例推荐PrimeTechBlog的初试WebStorage之localstorage

  所以建议,为兼容浏览器或者自己写兼容处理函数,或者干脆不用storage事件。

  实例

一些小点:

   localStorage要通过域名访问的方式才能起作用

 如果调用clear()方法,那么key、oldValue和newValue都会被设置为null。

  localStorage使用方式一致

&#;localStorage - 没有时间限制的数据存储&#;sessionStorage - 针对一个 session 的数据存储

localStorage提供了几个方法:

1、存储:localStorage.setItem(key,value)

如果key存在时,更新value

2、获取:localStorage.getItem(key)

如果key不存在返回null

3、删除:localStorage.removeItem(key)

一旦删除,key对应的数据将会全部删除

4、全部清除:localStorage.clear()

某些时候使用removeItem逐个删除太麻烦,可以使用clear,执行的后果是会清除所有localStorage对象保存的数据

5、遍历localStorage存储的key

.length 数据总量,例:localStorage.length.key(index) 获取key,例:var key=localStorage.key(index);

6、存储JSON格式数据

JSON.stringify(data) 将一个对象转换成JSON格式的数据串,返回转换后的串JSON.parse(data) 将数据解析成对象,返回解析后的对象

备注:localStorage存数的数据是不能跨浏览器共用的,一个浏览器只能读取各自浏览器的数据,储存空间5M。

JavaScript事件 "事件对象"的注意要点 在触发DOM上的某个事件时,会产生一个事件对象event。DOM中的事件对象兼容DOM的浏览器会将一个event对象传入到事件处理程序中。event对象包含与创建它

JavaScript事件类型中UI事件详解 DOM3级事件规定了一下几类事件UI事件,当用户与页面上的元素交互时除法;焦点事件,元素获得或失去焦点;鼠标事件,通过鼠标在页面上执行操作;

基于javascript实现随机颜色变化效果 本文实例讲解了基于javascript实现随机颜色变化效果,分享给大家供大家参考,具体内容如下htmlheadmetahttp-equiv="Content-Type"content="text/html;charset=gb"/title

标签: js中的

本文链接地址:https://www.jiuchutong.com/biancheng/383799.html 转载请保留说明!

上一篇:javascript图片切换综合实例(循环切换、顺序切换)(javascript图片切换代码)

下一篇:JavaScript事件 "事件对象"的注意要点

  • 公司债券和企业债券哪个风险大
  • 征地补偿费谁来支付
  • 不在经营范围内开票会受到什么惩罚
  • 盈利就是净利润吗
  • 委托开发票的证明怎么写
  • 股东公司
  • 汇算清缴后发生销售退回会计分录
  • 工程报废及毁损如何做会计处理合适呢?
  • 出借包装物收取的押金属于什么
  • 增值税哪些可以全额抵扣
  • 生产型企业一般会有哪些外来文件
  • 统借统还账务处理流程
  • 委托代销商品委托方发出商品的分录
  • 销售返利是冲减收入还是做销售费用
  • 合同银行账户与开票信息不一致会计如何处理
  • 应收账款抹零会计分录
  • 小规模减半征收什么时候开始
  • 税务局备案的企业是什么
  • 笔记本电池保养注意事项
  • 社会保险费的征收程序
  • 累积带薪缺勤金额怎么算
  • ubuntu16.04lts
  • ahqinit.exe是什么进程 ahqinit是安全的进程吗
  • 小微企业所得税怎么算
  • debian更换国内源教程
  • 移动列表格
  • mavon-editor的使用
  • 财行〔2019〕11号代扣代缴手续费的解读
  • php实现分页查询
  • 职工教育经费的计提比例是多少
  • php页面跳转实现什么功能
  • tar压缩解压缩命令
  • 微信小程序开发一个多少钱
  • 并发操作的定义
  • 事业结余是事业单位当年全部收支相抵后的余额
  • 合并报表的收入就是相加么
  • 公司赠送客户的产品怎么核算
  • mysql常见报错
  • SQLServer 2008 Merge语句的OUTPUT功能
  • 在sysservers中找不到服务器
  • 劳务公司已开票怎么入账
  • 小规模纳税人需要每月清卡吗
  • 购进新车旧车置换流程
  • 购置环保设备一次性扣除
  • 小规模城建税减半征收2020新政策
  • 融资租赁期间的维修费由谁承担
  • 一次性开票分期收入账务处理
  • 物业公司收的停车费做什么科目
  • 发票开错抬头做红字发票的账务处理是?
  • 承租人融资租赁会计账务处理
  • 发生的计提费用没有发生怎么办
  • 买车险怎么打折
  • 保险公司代扣的车船使用税分录
  • 月末一般要结转哪些会计科目
  • 影响企业所得税的因素
  • 房地产行业预缴土地增值税
  • 年末结转本年利润分录
  • 其他综合收益要转入投资收益吗
  • 企业的专利收费是多少
  • 已认证专票发现地址为错误
  • 税务局三代手续费是什么
  • 汇算清缴后缴纳所得税会计分录
  • 劳务费发票可以抵扣进项税吗
  • 企业建账前应考虑什么
  • Win7 64位旗舰版系统中实现照片的批量重命名
  • 本地磁盘安装
  • Win10 Mobile RS2预览版14926已知问题和解决方法汇总 谨慎升级
  • windows7网速慢怎么解决
  • 东芝笔记本配件
  • windows7怎么禁用网络
  • win7怎么查是不是正版
  • win8打开ie浏览器
  • jQuery实现的AJAX简单弹出层效果代码
  • dos测试网络连接
  • python语言怎么用
  • vs2010编译器在哪里?
  • 对超市的建议和意见怎么写简短
  • 发票测试纸在哪里打印
  • 陕西电子税务局官网
  • 党员逝世可否盖党旗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设