Web 本地存储和Vue本地存储实例

news/2024/7/10 0:18:45 标签: 字符串, js, vue, javascript, python

Web 本地存储

Web Storage API

关键对象

  • window.sessionStorage对象用于区域存储;
  • window.localStorage对象用于本地存储。

特点

  1. 数据的设置和读取比较方便。
  2. 容量较大,sessionStorage大约为5MB,localStorage大约为20MB。
  3. 只能存储字符串,若想要存储JSON对象,则可以使用window.JSON.stringify()或者parse()进行序列化和反序列化编码

区别

sessionStorage的存储周期只有一次会话(关闭浏览器就会消失)

localStorage的存储周期是永久的(关闭浏览器数据还在),除非用户手动清除浏览器缓存文件

属性和方法

window.localStorage.setItem('键','值')

window.sessionStorage.setItem('键','值')

方法/属性描述
key(n)该方法用于返回存储对象中第n个key的名称
setItem(key, value)该方法接收一个键名和值作为参数,将会把键值对添加到存储中,如果键名存在,则更新其对应的值
getItem(key)该方法接收一个键名作为参数,返回键名对应的值
removeItem(key)该方法删除键名为key的存储内容
clear()该方法清空所有存储内容
length该属性返回Storage存储对象中包含的item的数量

localStorage简单数据存储实例

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <input type="text" id="username">
    <button id="setData">设置数据</button>
    <button id="getData">获取数据</button>
    <button id="delData">删除数据</button>

    <script>
        var username = document.querySelector('#username');
        // 单击“设置数据”按钮,设置数据
        document.querySelector('#setData').onclick = function () {
            var val = username.value; // 获取username里面的值
            //window.sessionStorage.setItem('username', val);//一个会话,关闭网页后,数据不会保存
            window.localStorage.setItem('username',val)//只要不主动清除,一直都在
        };
        // 单击“获取数据”按钮,获取数据
        document.querySelector('#getData').onclick = function () {
            // alert(window.sessionStorage.getItem('username'));
            alert(window.localStorage.getItem('username'))
        };
        // 单击“删除数据”按钮,删除数据
        document.querySelector('#delData').onclick = function () {
            // window.sessionStorage.removeItem('username');
            window.localStorage.removeItem('username')
        };

        if (window.sessionStorage) {
            // 浏览器支持sessionStorage
        } else if (window.localStorage) {
            // 浏览器支持localStorage
        }
    </script>

    </script>
</body>
</html>

vue中的实例标签记录器">localStorage在Vue中的实例(标签记录器)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"
        integrity="sha384-t1tHLsbM7bYMJCXlhr0//00jSs7ZhsAhxgm191xFsyzvieTMCbUWKMhFg9I6ci8q"
        crossorigin="anonymous"></script>
 
    <style>
        body {
            padding: 0;
            margin: 0;
        }
        .divcenter {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            width: 500px;
            height: 50%;
        }
        p {
            border: solid 1px;
            margin: 0px;
            padding: 0px;
        }
        .spanX {
            float: right;
            margin-right: 10px;
            width: 10px;
 
        }
        span {
            cursor: pointer;
        }
 
        h2 {
            text-align: center;
        }
    </style>
</head>
 
<body>
    <div id="app" class="divcenter">
        <h2>标签记录器</h2>
        <!--文本框,设置双向绑定和回车事件-->
        <div>
            <input type="text" placeholder="请输入相应信息后按回车键!" v-model="text" @keyup.Enter="info"
                style="width: 100%;height: 40px;">
        </div>    
        <div>
               <!--回车后添加的标签和删除按钮-->
            <p v-for="(list,index) in arr">
                <span style="background-color: blanchedalmond;"> {{index+1}} </span>
                {{list}}
                <span class="spanX" @click="del(index)">x</span>
            </p>   
               <!--显示总数和清空按钮-->
            <div style="border: solid 1px;" v-show="arr.length!=0">
                <span>总数:{{arr.length}}</span>
                <span style="float: right;" @click="delAll">Clear</span>
            </div>
        </div>
    </div>
 
    <script>
        var app = new Vue({
            el: "#app",
            data: {
                //记录数据的数组,将保存到localStorage的字符串数据转换为对象数据重新保存到数组中
                arr: JSON.parse(window.localStorage.getItem('UserData')||'[]'),
                text: "",
            },
            methods: {
                //回车触发事件,把文本框里的内容保存到数组arr中
                info: function () {
                    //在末尾添加一条数据
                    this.arr.push(this.text);
                    this.text = "";
                },
                //单击删除按钮触发事件,清除指定下标数组的值
                del: function (index) {
                    //根据下标删除1条数据
                    this.arr.splice(index, 1);
                },
                //单击清空按钮,清除数组arr里所有是值
                delAll: function () {
                    this.arr = [];
                }
            },
       
            //监听事件
            watch:{
                //数据在标签内部改变是否触发:true
                deep:true,
                //要记录数据的数组,(名字要好保存数据的数组名一致),当arr数据发送改变时触发,新的数据返回到newVale中
                arr(newVale){
                    //将新的对象数据转换为字符串数据赋值给变量
                    let json_data=JSON.stringify(newVale)
                    //将字符串数据按照键值对的方式保存到localStorage中
                    window.localStorage.setItem('UserData',json_data)
                }        
            }
        })  
    </script>
</body>
</html>

http://www.niftyadmin.cn/n/1508110.html

相关文章

gridview 在已有数据的基础上添加数据_「应用界面优化」Winform分页控件录入数据并保存详解...

点击“了解更多”获取DevExpress v20.2完整版下载一般情况下&#xff0c;我们都倾向于使用一个组织比较好的独立界面来录入或者展示相关的数据&#xff0c;这样处理比较规范&#xff0c;也方便显示比较复杂的数据。不过在一些情况下&#xff0c;我们也可能需要直接在GridView表…

Mysql存储过程(转)

一、MySQL 创建存储过程 “pr_add” 是个简单的 MySQL 存储过程&#xff0c;这个存储过程有两个 int 类型的输入参数 “a”、“b”&#xff0c;返回这两个参数的和。 drop procedure if exists pr_add;-- 计算两个数之和create procedure pr_add(a int,b int)begindeclare c in…

移动端页面布局中的流动布局(百分比布局)和弹性布局

移动端页面布局 一、流式布局(百分比布局) 概念&#xff1a;流式布局是一种等比例缩放布局方式&#xff0c;在CSS代码中使用百分比来设置宽度&#xff0c;所以也称百分比自适应布局。流式布局实现方法是&#xff0c;将CSS固定像素宽度换算为百分比宽度。 换算格式&#xff1a;目…

mysql聚族索引自增长_【Mysql优化】聚簇索引与非聚簇索引概念

必须为主键字段创建一个索引&#xff0c;这个索引就是所谓的"主索引"。主索引与唯一索引的唯一区别是&#xff1a;前者在定义时使用的关键字是PRIMARY而不是UNIQUE。首先明白两句话:innodb的次索引指向对主键的引用 (聚簇索引)myisam的次索引和主索引 都指向物理行…

View 的measure 和onMeasure

最近有人问了我关于measure 和 onMeasure的一些问题&#xff0c;什么时候调用measure方法&#xff0c; 两者的区别&#xff0c;什么时候重写onMeasure方法。其实网上有很多人写过这方面的博客。我觉得不要因为网上有了&#xff0c;就不写。看懂是一回事&#xff0c;讲出来是一回…

全局API之Vue.set 监听数据层的数据变化

全局API之Vue.set 监听数据层的数据变化 Vue.set Vue的核心具有一套响应式系统&#xff0c;简单来说就是通过监听器监听数据层的数据变化&#xff0c;当数据改变后&#xff0c;通知视图也自动更新。 Vue.set用于向响应式对象中添加一个属性&#xff0c;并确保这个新属性同样是响…

戴尔 软件定义的存储_戴尔存储服务器MD3800F双控的详细配置教程之软件配置篇主机映射...

前言在上一篇文章中&#xff0c;我讲解了戴尔存储服务器MD3800F双控的详细配置教程之软件安装&#xff0c;主要是用这个软件来对存储服务器的配置和管理。这里&#xff0c;我还是将使用场景和配置都贴一下。使用场景&#xff1a;我先说一下我这边的使用场景&#xff0c;我这边之…

ios UIWebview本地加载H5网页

注意两点 1.拖动文件到工程中选择create folder&#xff0c;文件夹为蓝色 --不要让文件参与编译&#xff0c;而只是让文件加入进来 2.加载方式pathforresorth oftype indirectory 转载于:https://www.cnblogs.com/liutaoboke/p/6264563.html