网络编程
位置:首页>> 网络编程>> 网页设计>> 跨浏览器的本地存储(二):DOM:Storage

跨浏览器的本地存储(二):DOM:Storage

作者:blank 来源:怿飞blog 发布时间:2008-08-15 13:39:00 

标签:DOM,浏览器,存储

跨浏览器的本地存储(一):userData behavior

DOM Storage,是基于 Web Applications 1.0 specification 中介绍的 Structured client-side storage。相比 Cookies 来说,DOM Stroage 空间更大、更安全、更易于使用的。目前它只在基于Moziila的浏览器中可以使用,从 Firefox2 开始。

一、DOM:Storage: sessionStorage

浏览器支持:Firefox 2.0+

基本语法:

  • // 设置 key 值
    sessionStorage.key = value;

  • // 获取 key 值
    value = sessionStorage.key;

备注:

  1. 作为每个 window 对象的属性存在的全局对象,即:可以通过 sessionStorage 或者 window.sessionStorage 来访问它们。

  2. sessionStorage 含有一个在页面会话有效期内(只要页面没有关闭,一个页面会话就始终保持着,且当页面被重新载入或恢复时“复活”,而打开一个新的标签页或新窗口都会初始化新的会话)可用的存储区域。

  3. sessionStorage 持有那些应该保存的临时数据,一旦浏览器突然被刷新时,可恢复。

  4. sessionStorage 暂时还没有实现在浏览器崩溃后存储和恢复数据的功能( bug 339445 )。

更多信息:sessionStorage specification

样例:自动保存文本字段的内容,如果浏览器突然被刷新,就恢复字段内容,这样就不会丢失任何输入了。

// 获得我们要跟踪的那个文本字段var field = document.getElementById("field");// 看看我们是否有一个autosave的值// (这将只会在页面被突然刷新时发生)if ( sessionStorage.autosave ) {    // 恢复文本字段中的内容    field.value = sessionStorage.autosave;}// 每秒钟检查一次文本字段的内容setInterval(function(){    // 并把结果保存到会话存储对象中    sessionStorage.autosave = field.value;}, 1000);

二、DOM:Storage: globalStorage(重点)

浏览器支持:Firefox 2.0+

基本语法:

  • globalStorage['developer.mozilla.org'] —— 在developer.mozilla.org下面所有的子域都可以通过这个存储对象来进行读和写。

  • globalStorage['mozilla.org'] —— 在mozilla.org域名下面的所有网页都可以通过这个存储对象来进行读和写。

  • globalStorage['org'] —— 在.org域名下面的所有网页都可以通过这个存储对象来进行读和写。

  • globalStorage[''] —— 在任何域名下的任何网页都可以通过这个存储对象来进行读和写。

方法属性:

  • setItem(key, value) —— 设置或重置 key 值。

  • getItem(key) —— 获取 key 值。

  • removeItem(key) —— 删除 key 值。

或者:

  • // 设置 key 值
    window.globalStorage["planabc.net"].key = value;

  • // 获取 key 值
    value = window.globalStorage["planabc.net"].key;

备注:

  1. 作为每个 window 对象的属性存在的全局对象,即:可以通过 globalStorage 或者 window.globalStorage 来访问它们。

  2. Storage 空间:整个域名的默认 Storage 大小为 5MB (不过 Storage 区域的大小用户可以自定义),globalStorage['net'] 为 2MB,globalStorage['planabc.net'] 为 3MB,如果超过限制,则会报错。

  3. Firefox 支持 Storage 事件:document.addEventListener(”storage”, eventHandler, false);。

  4. Firefox 目前还没有实现 globalStorage[tld] 和 globalStorage[''] (会抛出一个安全错误),这是由于对于这些名字空间可以进行随意读写的话是有安全漏洞的。

  5. Firefox 2 允许访问比当前文档域名层次高的存储的对象,由于安全的因素 Firefox 3 中不再允许。

更多信息:globalStorage specification

样例:DOM Storage Test

0
投稿

猜你喜欢

  • 用Dreamweaver制作网页时,如果插入的图片、GIF动画、声音、视频或链接的网页是用中文命名的,在用IE浏览器浏览时可能显示不出来。以
  • 今天交流会上,分享前端的开发经验,有一条虽然很快带过,但是我倒是印象蛮深刻的,就写点小结来分享一下吧。不知道是标准害了大家还是大家害了标准,
  • 今天我和中国著名画家"渔人"谈了一个关于"怎样才能设计好"的问题,他给我说了一句话,得益不浅,那句话
  • 两个多月来唯一一次有时间哄么么睡觉,我先给他讲了遍《从前有座山》,还是不睡。又给他讲了这个“保安的故事”:小A是名很敬业的保安,负责保护客户
  • 简单的仿图片验证码,适合新手简单的仿图片验证码演示,很容易被破解,实用性不大,但拿出来给新手学习一下还是不错的:JScript.Asp代码示
  • 方法很简单,实现原理:使用asp的Request.ServerVariables("HTTP_REFERER") 判断来
  • 直接看代码: 代码如下:Class GoogleTranslator sub Class_Initialize
  • 编写思路:把本地文件在客户端通过base64编码以后发送目的地.测试过程中,上传文件过大,导致超时不成功.后来经过改善.把编码分段发送.测试
  • 1. 用Dreamweaver 4.0轻松设计会自动弹性调整的网页 首先需要保证的是你的页面内容采用了表格的格式,然后打开你要编辑的页面,按
  • 如何在ASP.NET中使用ADO.NET连接数据库?以连接Access数据库为例,步骤如下:一、我们来用有源ODBC DSN的方法和无源OL
  • 对于个人用户来说,除了病毒和木马,网页中的隐形代码也开始严重地威胁着我们的安全,但大多数人却缺乏自我保护意识,对隐形代码的危害认识不够,甚至
  • 在最近一次项目有一个需求,点击按钮——异步提交——异步响应返回——根据响应返回值新开窗口。这有两个要点:异步响应之前不知道要打开窗口的URL
  • 一直以来,jQuery是我最喜欢的框架之一。1月14号 1.4 Released版本发布后,就迫不及待去了解了一下1.4版本对比以往1.3.
  • 使用MySQL,目前你可以在三种基本数据库表格式间选择。当你创建一张表时,你可以告诉MySQL它应该对于表使用哪个表类型。MySQL将总是创
  • javascript中要判断一个变量是否为array通常是比较困难的,因为var a = [];alert(t
  • 1:mysql是我们使用最多的数据库,如果在日常中正确的对mysql数据进行备份,下面我们就来做这事,通过脚本来实现############
  • 研究编码,得知GB2312编码与区位码的关系,尝试之后,得此程序。搜索,似乎没人写,故发此地。1.简述(1)GB2312标准的定义,其实就是
  • 语法:CREATE TRIGGER trigger_name trigger_time trigger_eventON tbl_name F
  • 有在论坛上看到一帖,《请教查询出连续日期记录的方法》,截图如下:Insus.NET尝试写了程序并做了测试,可以得到预期的结果,SQL代码可参
  • 作为一名数据库管理员,在进行代码迁移之前,我总是尽力给提交于开发环境的代码一个完整的面貌。但是,不得不承认,我不能保证不发生任何可能破坏开发
手机版 网络编程 asp之家 www.aspxhome.com