`

H5本地存储

    博客分类:
  • HTML
阅读更多

HTML5本地存储:优于 cookies

【什么是 HTML 本地存储?】

通过本地存储(Local Storage),web 应用程序能够在用户浏览器中对数据进行本地的存储。

在 HTML5 之前,应用程序数据只能存储在 cookie 中,包括每个服务器请求。本地存储则更安全,并且可在不影响网站性能的前提下将大量数据存储于本地。

与 cookie 不同,存储限制要大得多(至少5MB),并且信息不会被传输到服务器。

本地存储经由起源地(origin)(经由域和协议)。所有页面,从起源地,能够存储和访问相同的数据。

【HTML 本地存储对象】

HTML 本地存储提供了两个在客户端存储数据的对象:

 ① window.localStorage - 存储没有截止日期的数据

 ② window.sessionStorage - 针对一个 session 来存储数据(当关闭浏览器标签页时数据会丢失)

在使用本地存储时,请检测 localStorage 和 sessionStorage 的浏览器支持:

 

 

if (typeof(Storage) !== "undefined") {
    // 针对 localStorage/sessionStorage 的代码
    alert("支持H5本地缓存")
} else {
    // 抱歉!不支持 Web Storage ..
    alert("不支持H5本地缓存")
}

① localStorage 对象

localStorage 对象存储的是没有截止日期的数据。当浏览器被关闭时数据不会被删除,在下一天、周或年中,都是可用的

 

<div id="result"></div>
<script>
// Check browser support
if (typeof(Storage) !== "undefined") {
    // Store
    localStorage.setItem("lastname", "Gates");
    // Retrieve
    document.getElementById("result").innerHTML = localStorage.getItem("lastname");
} else {
    document.getElementById("result").innerHTML = "抱歉!您的浏览器不支持 Web Storage ...";
}
</script>

 实例解释:

 

 1 . 创建 localStorage 名称/值对,其中:name="lastname",value="Gates"

 2 .取回 "lastname" 的值,并把它插到 id="result" 的元素中

上例也可这样写:

 

// 存储
localStorage.lastname = "Gates";
// 取回
document.getElementById("result").innerHTML = localStorage.lastname;

 

删除 "lastname" localStorage 项目的语法如下:

 

localStorage.removeItem("lastname");

 

注释:名称/值对始终存储为字符串。如果需要请记得把它们转换为其他格式!

下面的例子对用户点击按钮的次数进行计数。在代码中,值字符串被转换为数值,依次对计数进行递增:

 

<script>
function clickCounter() {
    if(typeof(Storage) !== "undefined") {
        if (localStorage.clickcount) {
            localStorage.clickcount = Number(localStorage.clickcount)+1;
        } else {
            localStorage.clickcount = 1;
        }
        document.getElementById("result").innerHTML = 
             "您已经点击这个按钮 " + localStorage.clickcount + " 次。";
    } else {
        document.getElementById("result").innerHTML = 
             "抱歉!您的浏览器不支持 Web Storage ...";
    }
}
</script>
<p><button onclick="clickCounter()" type="button">请点击这里!</button></p>
<div id="result"></div>
<p>请点击按钮使计数器递增。</p>
<p>请关闭浏览器或标签页,然后再试一次,计数器将继续计数(不会重置)。</p>

  ② sessionStorage 对象

 

  sessionStorage 对象等同 localStorage 对象,不同之处在于只对一个 session 存储数据。如果用户关闭具体的浏览器标签页,数据也会被删除。

下例在当前 session 中对用户点击按钮进行计数:

 

<script>
function clickCounter() {
    if(typeof(Storage) !== "undefined") {
        if (sessionStorage.clickcount) {
            sessionStorage.clickcount = Number(sessionStorage.clickcount)+1;
        } else {
            sessionStorage.clickcount = 1;
        }
        document.getElementById("result").innerHTML = 
            "在本 session 中,您已经点击这个按钮 " + sessionStorage.clickcount + " 次。";
    } else {
        document.getElementById("result").innerHTML = 
            "抱歉!您的浏览器不支持 Web Storage ...";
    }
}
</script>
<p><button onclick="clickCounter()" type="button">请点击这里</button></p>
<div id="result"></div>
<p>请点击按钮使计数器递增。</p>
<p>请关闭浏览器或标签页,然后再试一次,计数器会重置。</p>

 

 

 

 

 

 

 

 

 

 

 

 

分享到:
评论

相关推荐

    基于JSON的H5本地存储

    基于JSON的H5本地存储,提供一套简易、强大的API,几乎不需要学习即可直接使用

    myStorage.js-兼容性的H5本地存储

    把localStorage跟cookieStorage封装起来,当客户端不兼容H5本地存储时可自动切换成Cookie存储

    webSQL封装

    H5本地存储

    上传到本地表单数据和图片上传插件的使用

    本文将详细介绍如何使用H5本地存储功能以及图片上传插件,帮助开发者实现更高效、流畅的用户体验。 一、H5本地存储 H5引入了两种主要的本地存储方式:localStorage和sessionStorage。 1. localStorage: ...

    h5 本地缓存

    综上所述,H5的本地缓存通过Service Worker和Cache API提供了强大的离线存储能力,使得Web应用能在无网络环境下正常运行,同时提高了页面加载速度。在实际开发中,合理封装和运用这些技术,可以显著提升Web应用的...

    HTML5的本地存储

    本地存储主要包括两个API:`localStorage` 和 `sessionStorage`。 #### 二、`localStorage` `localStorage` 是HTML5本地存储机制的一部分,用于长期保存数据。这些数据即使在用户关闭浏览器后仍然保留,并且只有...

    H5 简单demo示例模板

    Web Storage(包括`sessionStorage`和`localStorage`)提供了更大的本地存储空间。 二、Vue与React框架结合H5 1. **Vue.js**:这是一个轻量级的MVVM框架,它简化了前端开发流程,提供了响应式的数据绑定和组件化...

    h5阿里播放器源码_h5播放_h5阿里播放器源码_bigplay.com_

    《深入解析H5阿里播放器源码:打造流畅的在线视频体验》 在现代互联网技术中,HTML5(H5)已经成为构建富媒体应用的重要工具,尤其在视频播放领域,H5阿里播放器源码因其高效、灵活和跨平台的特点备受青睐。本文将...

    H5 调用android 相机拍照

    本知识点将详细阐述如何在H5中调用Android本地相机进行拍照,并确保在Android 5.0、6.0等不同版本系统上的兼容性。 首先,我们需要理解H5与Android原生代码的交互机制。在Android应用中,通常会使用WebView组件来...

    androidstudio 打包h5 网页地址

    - 加载H5网页地址,可以是本地存储的HTML文件,也可以是远程URL: ```java WebView webView = findViewById(R.id.webView); webView.getSettings().setJavaScriptEnabled(true); webView.loadUrl(...

    MUI H5+长按图片下载至本地相册源码示例

    MUI框架提供了与原生设备交互的能力,包括访问本地存储和相册。在处理长按事件的函数中,我们需要获取到被长按的图片URL,然后调用MUI的API将图片保存至本地。这个过程可能涉及到图片的Base64编码或Blob对象转换,以...

    前端H5获取Android原生相册文件和拍照功能直接重新WebView的方法即可

    在H5页面中,`&lt;input type="file"&gt;`标签常用于让用户选择本地文件,例如图片。在iOS设备上,这个标签基本可以正常工作,用户可以通过系统弹出的文件选择器选择相册或相机。然而,Android的WebView默认情况下可能不...

    h5语音录制,语音播放,语音保存本地,用的recoder.js,我自己封装过 了的

    在Electron项目中,由于其集成了Chromium和Node.js,我们可以进一步扩展这个功能,例如利用Node.js的`fs`模块直接将音频文件写入到Electron应用的本地存储中,提供更为便捷的本地管理方式。 在压缩包文件`Voice`中...

    H5版本的捕鱼游戏

    这些本地存储技术使得游戏状态可以保存,即使玩家关闭浏览器,再次打开时也能恢复之前的游戏进度。 捕鱼游戏中,网络通信功能也至关重要,H5提供了WebSocket协议,用于实现双向实时通信。这样,玩家的操作可以即时...

    H5滑动验证+H5源码

    3. **数据持久化**:如果需要,可以将验证状态存储在本地,以便在刷新页面后恢复。 4. **性能优化**:针对大量用户并发访问的情况,考虑优化代码性能,减少内存占用和计算时间。 5. **API整合**:将验证结果通过...

    430个h5小游戏源码demo

    4. 数据存储:学习如何使用本地存储或Web Storage来保存用户数据和进度。 5. 性能优化:查看源码中如何通过优化渲染、减少重绘等手段提升游戏性能。 6. 音效与动画:了解如何整合Web Audio和CSS3动画,增强游戏体验...

    40个H5小游戏完整源码-new

    10. **Web存储**:利用HTML5的localStorage或sessionStorage,可以实现游戏数据的本地存储,例如记录玩家分数。 通过研究这些源码,开发者不仅可以学习到基本的H5游戏开发技术,还能了解到如何构建一个完整的、交互...

    h5app拍照或者图库选择图片限制图片数量demo

    H5提供了多种API来支持这一功能,如`&lt;input type="file"&gt;`元素用于选择本地文件,以及FileReader API用于预览和处理用户选择的文件。此外,可能还涉及到File API,用于读取、操作和上传文件。 **详细知识点:** 1....

Global site tag (gtag.js) - Google Analytics