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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 浅谈辄止_java forkjoinpool

    浅谈辄止_java forkjoinpool文章目录一、ForkJoin是什么?它能用来实现什么功能?二、ForkJoin的实现原理三、ForkJoin的简单使用一、ForkJoin是什么?它能用来实现什么功能?二、ForkJoin的实现原理三、ForkJoin的简单使用在这里插入代码片…

    2022年9月20日
    5
  • iscsiadm命令基本用法[通俗易懂]

    iscsiadm命令基本用法[通俗易懂]发现目标iscsiadm-mdiscovery-tsendtargets-p192.168.1.1:3260-mdiscovery指定模式为discovery-p192.168.1.1:3260指定目标ip和端口登入节点iscsiadm-mnode–Tiqn.1997-05.com.test:raid-p192.168.1.1:3260-l系统启动时自动登入iscsiadm-mnode–Tiqn.1997-05.com.test:raid-p192.16

    2022年8月23日
    8
  • 关系数据库的范式理论_数据库规范化理论依据

    关系数据库的范式理论_数据库规范化理论依据文章目录求关系模式最高达到第几范式的步骤通俗理解1NF,2NF,3NF.如何求关系模式的候选码如何求闭包函数依赖求关系模式最高达到第几范式的步骤根据给定的U和F,首先求它的候选码根据候选码判断关系F中的函数关系是否满足第二范式,若不满足则为关系模式的规范化最高为第一范式然后判断是否存在非主属性传递依赖,如果存在则不满足第二范式,如果不存在则关系模式的规范化最高为第三范式.通俗理解1N…

    2022年10月16日
    3
  • c++全局变量与静态变量「建议收藏」

    c++全局变量与静态变量「建议收藏」概述:全局变量和和由static修饰的静态变量都被储存在全局数据区。全局数据区的内存在程序运行时会被全部置’0′.这不同于局部变量,局部变量在栈上分配内存,但此块内存一般不为零,且编译器不会在局部变量被声明的地方为其置’0′,除非申明时对其初始化值为0.全局变量:申明在main函数外的变量被编译器视为全局变量。即其在整个文件的任何地方都可以使用它。对于其他源文件来说,全局变量…

    2022年5月13日
    40
  • spring的事务隔离级别「建议收藏」

    spring的事务隔离级别「建议收藏」spring的事务隔离级别

    2022年4月22日
    48
  • Rancher v1.2基础设施引擎整体架构分析

    Rancher v1.2基础设施引擎整体架构分析

    2022年3月8日
    42

发表回复

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

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