html5之本地存储localStorage示例

html5之本地存储localStorage示例

<!-- 
注意: 
index.html 文件中的IP指的是服务器的访问地址,请根据具体需求走。本案例只做参考。
返回的json格式,大家可通过本地.json文件模拟,具体格式如下:
{
    "cindex": 0,
    "max": 0,
    "min": 0,
    "p_id": 0,
    "paper_id": 0,
    "score": "",
    "scoreRule": "",
    "score_type": "",
    "title": "哈哈哈哈哈",
    "totalNum": 0,
    "type": 1,
    "unmber": ""
}
-->        

 

index.html 文件

<!doctype html>
<html lang="en">
 <head>
  <title> html5本地缓存示例 </title>
  <meta charset="utf-8">
  <meta name="description" content="html5本地缓存示例">
 </head>

 <body>
 <div>
    <input type="text" id="jsonName"/>
    <input type="button" value="按存储名查询" onclick="findStorage()"/>
    <input type="button" value="按存储名删除" onclick="deleteStorage()"/>
    <div id="storageInfo">
    </div>
 </div>

 <p>
    1、针对客户端而言,localStorage 本地永久存储;sessionStorage 临时存储;<br/>
    2、localStorage 与 sessionStorage 存储大小5MB;注意不要存储敏感信息<br/>
    3、以ajax取得数据为例,将返回的json存储至localStorage中
 </p>
 <script type="text/javascript" src="js/lib/jquery-1.9.1.min.js"></script>
 <script>
    /*定义对象*/
    var questionIPort = "http://IP/yitaifront/normalcase/test?id=";

    function getElObj(elId){
    //取对象
        return document.getElementById(elId);
    }

    function isEmptyObj(data){
    //判空
        if(data == null || data == ""){
            return true;
        }else{
            return false;
        }
    }

    function saveStorage(saveName,data){
    //存数据
        if(isEmptyObj(data)){
            try{
                 console.log("数据保存失败");
                 window.localStorage.setItem(saveName,"");
            }catch(oException){
                 if(oException.name == 'QuotaExceededError'){
                    removeAllStorage(saveName, "");  
                 }
            }
        }else{
            var str = JSON.stringify(data);
            try{
                 window.localStorage.setItem(saveName,str);
                 console.log("整个数据已保存,取值name为"+saveName);
            }catch(oException){
                 if(oException.name == 'QuotaExceededError'){
                    removeAllStorage(saveName, str);  
                 }
            }
        }
    }

    function removeAllStorage(saveName, str){
    //清空所有
        console.log('超出本地存储限定范围!');
        //如果历史信息不重要了,可清空后再设置
        localStorage.clear();
        window.localStorage.setItem(saveName,str);
    }

    function removeStorageByCount(count){
        var countInt = count-0;
        console.log(window.localStorage);
        for(var i = 1; i <= countInt; i++){
            var storageKey = window.localStorage.key(i);
            console.log(""+i+"个对象的key值为"+storageKey);
            window.localStorage.removeItem(storageKey);
        }
        console.log("超出本地存储限定范围!共删除"+i+"个对象");
    }

    function findStorage(){
    //查数据
        var targetObj = getElObj("jsonName").value;
        if(isEmptyObj(targetObj)){
            getElObj("storageInfo").innerHTML = "";
            return ;
        }else{
            var str = window.localStorage.getItem(targetObj);
            var data = JSON.parse(str);
            if(data != null && data != ""){
                getElObj("storageInfo").innerHTML = data.title;
                console.log(data.title);    
            }else{
                getElObj("storageInfo").innerHTML = "";
            }
        }
        console.log("查找......");
    }

    function deleteStorage(){
    //删数据
        var targetObj = getElObj("jsonName").value;
        if(isEmptyObj(targetObj)){
            return ;
        }else{
            window.localStorage.removeItem(targetObj);
            getElObj("storageInfo").innerHTML = "删除成功";
        }
        console.log("删除......");
    }

    function findQuestInfo(questionIPort, saveId){
    //接口调用
        $.ajax({
            url: questionIPort+saveId,
            dataType: "json",
            type: "get",
            beforeSend: function() {
    //请求前

            },
            success: function(response) {
    //请求成功
                if(response.code == 200){
                    saveStorage("questStorage"+saveId,response.data);
                }else{
                    saveStorage("questStorage"+saveId,"");
                }
            },
            complete: function() {
    //请求完成

            },
            error: function() {
    //请求出错
                saveStorage("questStorage"+saveId,"");
            }
        });
    }

    //查询保存数据 
    findQuestInfo(questionIPort, "118"); //单选题
    findQuestInfo(questionIPort, "181"); //多选题
    findQuestInfo(questionIPort, "135"); //填空题
    findQuestInfo(questionIPort, "182"); //主观题
    findQuestInfo(questionIPort, "166"); //数字记忆
    findQuestInfo(questionIPort, "167"); //词语记忆
    /*setTimeout(function(){
        removeStorageByCount(2);
    },3000);*/
    
 </script>
 </body>
</html>

 

转载于:https://www.cnblogs.com/mbsh/p/5163284.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/109155.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 捷达vs5顶配配置_VS窗体教程

    捷达vs5顶配配置_VS窗体教程使用VSCode优雅的书写Python代码

    2022年10月23日
    0
  • Qt之log数据展示模块简要实现

    Log模块主要用于实时测井数据的显示和测后曲线数据的预览和打印,为更好的展示对Qt中相关知识点的应用,特以Log模块为例对其进行简要实现。内容导图:一、功能需求1、界面效果图Log模块实现曲线

    2021年12月29日
    43
  • 可能是史上最全的权限系统设计

    可能是史上最全的权限系统设计权限系统设计前言权限管理是所有后台系统的都会涉及的一个重要组成部分,主要目的是对不同的人访问资源进行权限的控制,避免因权限控制缺失或操作不当引发的风险问题,如操作错误,隐私数据泄露等问题。目前在

    2022年7月4日
    22
  • 使用admixture进行群体结构分析「建议收藏」

    使用admixture进行群体结构分析「建议收藏」使用admixture进行群体结构分析

    2022年10月25日
    0
  • idea 2021.11.3 激活码_在线激活

    (idea 2021.11.3 激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~0…

    2022年3月28日
    44
  • python中的单引号和双引号的区别和用法_python中打印输出的语句

    python中的单引号和双引号的区别和用法_python中打印输出的语句python中的单引号和双引号的区别今天在码代码的过程中突然想到这个问题,于是上网浏览了一下,发现在python中两种表达方式是没有区别的,两种表达方式都可以用来表达一个字符串。但是这两种通用的表达方式,除了可以简化大家的开发,避免出错以外,还有一种好处,就是可以减转义字符的使用,使程序看起来更加简洁,更清晰。所以这里简单给大家分享一下,并举例说明。1.包含单引号的字符串假如我们想定义一个字符串my_str,其值为:I’mastudent,则可采用如下两种方式,通过转义字符“\”进行定义my_s

    2025年6月14日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号