BOM之本地数据存储
JavaScript中本地存储数据常用的,且兼容性较好的有两种方式,cookie和Storage。另外还可以使用location.hash临时存储少量关键信息。
一 location.hash
location.hash可以记录当前页面的状态,保存或分享当前页的url,再次打开该url时,网页还是保存(分享)时的状态。
如果要使用location.hash来存储状态数据,那么我们首先应该了解URL的大小限制。
虽然HTTP协议的RFC规范并没有详细规定URL的最大字符长度限制,但实际上,在浏览器或者服务器中总会存在限制的。这里的字符是指ASCII字符。
一般建议浏览器URL最大值:IE 2KB,Chrome 8KB,Firefox 64KB,Safari 72KB,Opera 192KB,注意这只是浏览器端的限制,实际使用还要根据不同的服务器端来做调整,例如apache 一般限制最大为8KB,nginx一般默认4KB等等。两者结合来看,我建议在开发中尽量把大小控制在2KB以内。
location.hash的主要目的并不是为了存储数据,它更重要的功能是可以无刷新修改页面,配合ajax技术实现前端路由,虽然现在使用H5的history API逐渐替代了这种方式,但我们还是可以了解一下它的原理,因为它的兼容性更好。
本篇主要讲解JS的数据存储,关于前端路由这里不会详细讲解。
二 document.cookie
1,cookie用于在客户端本地临时保存用户少量信息。
当用户打开一个网址时,浏览器可以把与该网址相关的少量用户信息存储在cookie中,当下一次用户再次打开相同网址时,浏览器会自动把cookie中存储的信息一起发送给服务器,这样服务器就能及时的返回和用户相关的信息。浏览器允许的cookie最大为4KB,不同浏览器同一域名下允许的cookie个数在20到50之间。
2,读取cookie
读取cookie会返回一个字符串,它以键值对的形式保存数据,每条数据用分号隔开。
注意:只能在使用http或者https协议访问网页时才能正确读写cookie,本地使用file协议无法使用cookie。
console.log(document.cookie);//"username=ren;age=12"
另外,每条cookie都有几个可选的键,用来设置/更新它自己,但在cookie中不能被显式的查看到:
path:规定cookie的路径,如果没有设置默认为当前文档的目录。
domain:设置域名,如果没有则默认为当前页面域名。
max-age:以秒来规定cookie的生存周期。可以设置负值使cookie过期。
expires:设置一个时间当做cookie的过期时间。基本可以用max-age替代。
secure:通过设置一个boolean值来规定通过http还是https传输cookie,新的规定是cookie只能通过https传输,所以这个键基本没用了。
3,添加cookie
要添加新的cookie信息很简单,但是这种方式只支持一条一条的写入:
document.cookie = "address=cd;max-age=360;path=/";
cookie和普通变量不同,普通变量经过上面的操作,原来的值将被覆盖,而cookie则执行了类似 cookie += “some text”的操作。
4,修改cookie
document.cookie = "address=sc;max-age=360;path=/”;
修改时path必须和创建时一致,不然浏览器会新增一条cookie数据。
5,删除cookie
如果要在cookie生存周期内手动的删除cookie,只需要把expires设置为以前的某一个时间或把max-age设置为负值即可:
document.cookie = “address=sc;expires=Thu,01 Jan 1970 00:00:00 GMT;path=/”;
document.cookie = "name=ren;max-age=-1;path=/";
需要注意的是,路径必须和创建这条cookie的路径一致,不然浏览器不会执行删除操作。
下面是我封装的一个以对象形式返回cookie的函数:
function getCookie(cookie){
if(!cookie){
return null;
}else{
var cookieArr = cookie.split(";");
var cookieObj = {};
for(let i = 0,len = cookieArr.length;i < len;i++){
cookieArr[i] = cookieArr[i].trim();
var cookieKey = cookieArr[i].split("=")[0];
var cookieVal = cookieArr[i].split("=")[1];
cookieObj[cookieKey] = cookieVal;
}
return cookieObj;
}
}
三 Storage
Storage分为window.localStorage和window.sessionStorage。
1,异同
localStorage是没有时间限制的(除非用户手动清理)数据存储,存储在本地硬盘。而sessionStorage是针对一个 session(会话)的数据存储,网页关闭,数据将丢失,他们存储数据的大小可达5MB。不同浏览器可能存在差异。
2,length
localStorage对象有一个length属性,表示存储了几条数据。
3,添加和修改数据
localStorage是一个对象,所以他的修改方法同普通对象:
localStorage.name = "ren";//普通对象方式
localStorage.setItem("age",12);//localtStorage提供的方法
console.log(localStorage.name);//"ren"
console.log(localStorage.getItem(age));//"12"
你可能会奇怪,localstorage.age为什么会返回字符串“12”,那是因为它只支持String类型的数据存储,所以系统在存储时会自动把数据转换成字符串。
4,删除
删除一项
localStorage.removeItem(age);
console.log(localStorage);//{name:age,length:1}
删除全部
localStorage.clear();
console.log(localStorage);//{length:0}
BOM之本地数据存储的更多相关文章
- Android本地数据存储复习
Android本地数据存储复习 Android无论是应用层还是系统层都需要在本地保存一些数据,尤其在应用层中使用的就更为普遍,大体有这么几种:SharedPreference,file,sqlite数 ...
- iOS开发——数据持久化&使用NSUserDefaults来进行本地数据存储
使用NSUserDefaults来进行本地数据存储 NSUserDefaults适合存储轻量级的本地客户端数据,比如记住密码功能,要保存一个系统的用户名.密码.使用NSUserDefaults是首 ...
- iOS APP之本地数据存储(译)
最近工作中完成了项目的用户信息本地存储,查阅了一些本地存储加密方法等相关资料.期间发现了一个来自印度理工学院(IIT)的信息安全工程师的个人博客,写了大量有关iOS Application secur ...
- Windows 8 应用开发 - 本地数据存储
原文:Windows 8 应用开发 - 本地数据存储 在应用中通常会遇到用户主动或被动存储信息的情况,当应用关闭后这些数据仍然会存储在本地设备上,用户下次重新激活应用时会自动加载这些数据.下 ...
- iOS开发技术分享(1)— iOS本地数据存储
iOS开发技术分享(1)— iOS本地数据存储 前言: 我本是一名asp.net程序员,后来加入了iOS游戏开发队伍,到现在也有一年多的时间了.这一年来,每天都干到2.3点钟才睡觉,不为别的,只为了学 ...
- 浏览器本地数据存储解决方案以及cookie的坑
本地数据存储解决方案以及cookie的坑 问题: cookie过长导致页面打开失败 背景: 在公司的项目中有一个需求是打开多个工单即在同一个页面中打开了多个tab(iframe),但是需要在刷新时只刷 ...
- Android之ListView,AsyncTask,GridView,CardView,本地数据存储,SQLite数据库
版权声明:未经博主允许不得转载 补充 补充上一节,使用ListView是用来显示列表项的,使用ListView需要两个xml文件,一个是列表布局,一个是单个列表项的布局.如我们要在要显示系统所有app ...
- cocos2d-html5开发之本地数据存储
做游戏时常常须要的一个功能呢就是数据的保存了,比方游戏最高分.得到的金币数.物品的数量等等.cocos2d-html5使用了html5.所以html5的数据保存方法是对引擎可用的: html5本地数据 ...
- 本地数据存储解决方案以及cookie的坑
本地数据存储解决方案以及cookie的坑 问题: cookie过长导致页面打开失败 背景: 在公司的项目中有一个需求是打开多个工单即在同一个页面中打开了多个tab(iframe),但是需要在刷新时只刷 ...
随机推荐
- numba,让python速度提升百倍
python由于它动态解释性语言的特性,跑起代码来相比java.c++要慢很多,尤其在做科学计算的时候,十亿百亿级别的运算,让python的这种劣势更加凸显. 办法永远比困难多,numba就是解决py ...
- idea使用springboot的webservice基于cxf
SpringBoot整合CXF实例: 服务端构建 <dependency> <groupId>org.apache.cxf</groupId> <artifa ...
- Eclipse中安装JRebel热部署教程
Eclipse中安装JRebel热部署教程 前言 Eclipse安装JRebel插件可快速实现热部署,节省了大量重启时间,提高开发效率. 本文只介绍Eclipse安装JRebel插件版本 ...
- Docker搭建Zookeeper&Kafka集群
最近在学习Kafka,准备测试集群状态的时候感觉无论是开三台虚拟机或者在一台虚拟机开辟三个不同的端口号都太麻烦了(嗯..主要是懒). 环境准备 一台可以上网且有CentOS7虚拟机的电脑 为什么使用虚 ...
- 一键部署 Spring Boot 到远程 Docker 容器,就是这么秀!
不知道各位小伙伴在生产环境都是怎么部署 Spring Boot 的,打成 jar 直接一键运行?打成 war 扔到 Tomcat 容器中运行?不过据松哥了解,容器化部署应该是目前的主流方案. 不同于传 ...
- Django之上传图片,分页,三级联动
Django1.8.2中文文档:Django1.8.2中文文档 上传图片 配置上传文件保存目录 1)新建上传文件保存目录. 2)配置上传文件保存目录. 后台管理页面上传图片 1)设计模型类. 2)迁移 ...
- 深入理解vmware虚拟网络
0x01:vmware workstation VMware Workstation是一款非常不错的虚拟机软件,许多爱好者用VMware,Workstation设计多种实现环境做测试.VMware W ...
- css_transition_animation(内含贝赛尔曲线详解)
区别: transition也叫过渡动画,主要是用于让一个元素从一种状态过渡到另一种状态效果,常用于主动触发的效果.例如移动端的页面切换(很常用).button点击效果(也很常见). animatio ...
- JVM中class文件探索与解析
一直想成为一名优秀的架构师的我,转眼已经工作快两年了,对于java内核了解甚少,闲来时间,看看JVM,吧自己的一些研究写下来供大家参考,有不对的地方请指正. 废话不多说,一起来看看JVM中类文件是如何 ...
- c# autofac结合WebApi的使用
一.下载相关类库引用 install-package Autofac install-package Autofac.Mvc4 install-package Autofac.WebApi2 二.配置 ...