目录
2.2、存储数据sessionStorage.setItem(key, value)
2.3、获取数据sessionStorage.getItem(key)
2.4、删除一个数据sessionStorage.removeItem(key)
2.5、删除全部数据sessionStorage.clear()
3.2、存储数据localStorage.setItem(key, value)
3.3、获取数据localStorage.getItem(key)
3.4、删除一个数据localStorage.removeItem(key)
3.5、删除全部数据localStorage.clear()
JS本地存储
一、本地存储特性
二、sessionStorage
2.1、sessionStorage特点
(1)生命周期为关闭浏览器窗口
(2)在同一个窗口(页面)下数据可以共享
(3)以键值对的形式存储使用
方法:
2.2、存储数据sessionStorage.setItem(key, value)
代码如下:
<input type="text">
<button class="set">存储数据</button>
<button class="get">获取数据</button>
<button class="remove">删除数据</button>
<button class="del">清空所有数据</button>
<script>
var ipt = document.querySelector('input');
var set = document.querySelector('.set')
var get = document.querySelector('.get')
//存储数据
set.addEventListener('click', function() {
//当我们点击之后,就可以把表单里的值存储起来
var val = ipt.value;
sessionStorage.setItem('uname', val);
})
</script>
运行结果:
2.3、获取数据sessionStorage.getItem(key)
代码如下:
<input type="text">
<button class="set">存储数据</button>
<button class="get">获取数据</button>
<button class="remove">删除数据</button>
<button class="del">清空所有数据</button>
<script>
var ipt = document.querySelector('input');
var set = document.querySelector('.set')
var get = document.querySelector('.get')
//存储数据
set.addEventListener('click', function() {
//当我们点击之后,就可以把表单里的值存储起来
var val = ipt.value;
sessionStorage.setItem('uname', val);
})
//获取数据
get.addEventListener('click', function() {
// 当我们点击之后,就可以把数据获取过来
console.log(sessionStorage.getItem('uname'));
})
</script>
运行结果:
2.4、删除一个数据sessionStorage.removeItem(key)
代码如下:
<input type="text">
<button class="set">存储数据</button>
<button class="get">获取数据</button>
<button class="remove">删除数据</button>
<button class="del">清空所有数据</button>
<script>
var ipt = document.querySelector('input');
var set = document.querySelector('.set')
var get = document.querySelector('.get')
var remove = document.querySelector('.remove')
//存储数据
set.addEventListener('click', function() {
//当我们点击之后,就可以把表单里的值存储起来
var val = ipt.value;
sessionStorage.setItem('uname', val);
sessionStorage.setItem('pws', val);
})
//获取数据
get.addEventListener('click', function() {
// 当我们点击之后,就可以把数据获取过来
console.log(sessionStorage.getItem('uname'));
})
//删除数据
remove.addEventListener('click', function() {
// 当我们点击之后,就可以把数据一条一条的删除
sessionStorage.removeItem('uname');
})
</script>
运行结果:
存储两个数据,只删除一个
2.5、删除全部数据sessionStorage.clear()
<input type="text">
<button class="set">存储数据</button>
<button class="get">获取数据</button>
<button class="remove">删除数据</button>
<button class="del">清空所有数据</button>
<script>
var ipt = document.querySelector('input');
var set = document.querySelector('.set')
var get = document.querySelector('.get')
var remove = document.querySelector('.remove')
var del = document.querySelector('.del');
//存储数据
set.addEventListener('click', function() {
//当我们点击之后,就可以把表单里的值存储起来
var val = ipt.value;
sessionStorage.setItem('uname', val);
sessionStorage.setItem('pws', val);
})
//获取数据
get.addEventListener('click', function() {
// 当我们点击之后,就可以把数据获取过来
console.log(sessionStorage.getItem('uname'));
})
//删除一个数据
remove.addEventListener('click', function() {
// 当我们点击之后,就可以把数据一条一条的删除
sessionStorage.removeItem('uname');
})
//删除全部数据
del.addEventListener('click', function() {
// 当我们点击之后,就可以把数据全部删除
sessionStorage.clear();
})
</script>
三、localStorage
3.1、localStorage特点
(1)声明周期永久生效,除非手动删除否则关闭页面也会存在
(2)可以多窗口(页面)共享(同一浏览器可以共享)
(3)以键值对的形式存储使用
方法:
3.2、存储数据localStorage.setItem(key, value)
代码如下:
<input type="text">
<button class="set">存储数据</button>
<button class="get">获取数据</button>
<button class="remove">删除数据</button>
<button class="del">清空所有数据</button>
<script>
var ipt = document.querySelector('input');
var set = document.querySelector('.set')
var get = document.querySelector('.get')
var remove = document.querySelector('.remove')
var del = document.querySelector('.del');
//存储数据
set.addEventListener('click', function() {
//当我们点击之后,就可以把表单里的值存储起来
var val = ipt.value;
localStorage.setItem('uname', val);
})
</script>
运行结果;
3.3、获取数据localStorage.getItem(key)
<input type="text">
<button class="set">存储数据</button>
<button class="get">获取数据</button>
<button class="remove">删除数据</button>
<button class="del">清空所有数据</button>
<script>
var ipt = document.querySelector('input');
var set = document.querySelector('.set')
var get = document.querySelector('.get')
var remove = document.querySelector('.remove')
var del = document.querySelector('.del');
//存储数据
set.addEventListener('click', function() {
//当我们点击之后,就可以把表单里的值存储起来
var val = ipt.value;
localStorage.setItem('uname', val);
})
//获取数据
get.addEventListener('click', function() {
// 当我们点击之后,就可以把数据获取过来
console.log(localStorage.getItem('uname'));
})
</script>
3.4、删除一个数据localStorage.removeItem(key)
<input type="text">
<button class="set">存储数据</button>
<button class="get">获取数据</button>
<button class="remove">删除数据</button>
<button class="del">清空所有数据</button>
<script>
var ipt = document.querySelector('input');
var set = document.querySelector('.set')
var get = document.querySelector('.get')
var remove = document.querySelector('.remove')
var del = document.querySelector('.del');
//存储数据
set.addEventListener('click', function() {
//当我们点击之后,就可以把表单里的值存储起来
var val = ipt.value;
localStorage.setItem('uname', val);
})
//获取数据
get.addEventListener('click', function() {
// 当我们点击之后,就可以把数据获取过来
console.log(localStorage.getItem('uname'));
})
//删除一个数据
remove.addEventListener('click', function() {
// 当我们点击之后,就可以把数据一条一条的删除
localStorage.removeItem('uname');
})
</script>
3.5、删除全部数据localStorage.clear()
<input type="text">
<button class="set">存储数据</button>
<button class="get">获取数据</button>
<button class="remove">删除数据</button>
<button class="del">清空所有数据</button>
<script>
var ipt = document.querySelector('input');
var set = document.querySelector('.set')
var get = document.querySelector('.get')
var remove = document.querySelector('.remove')
var del = document.querySelector('.del');
//存储数据
set.addEventListener('click', function() {
//当我们点击之后,就可以把表单里的值存储起来
var val = ipt.value;
localStorage.setItem('uname', val);
})
//获取数据
get.addEventListener('click', function() {
// 当我们点击之后,就可以把数据获取过来
console.log(localStorage.getItem('uname'));
})
//删除一个数据
remove.addEventListener('click', function() {
// 当我们点击之后,就可以把数据一条一条的删除
localStorage.removeItem('uname');
})
//删除全部数据
del.addEventListener('click', function() {
// 当我们点击之后,就可以把数据全部删除
localStorage.clear();
})
</script>
四、记住用户名案例
需求:
如果勾选记住用户名,下次用户打开浏览器,就在文本框里自动显示上次登录用户名
案例分析:
(1)把数据存储起来,用到本地存储;
(2)关闭页面,也可以显示用户名,所以用到localStorage;
(3)打开页面,先判断是否有这个用户名,如果有就在表单里面显示用户名,并且勾选复选框;
(4)当复选框发生改变的时候change事件;
(5)如果勾选,就存储,否则就移除。
代码:
<input type="text" id="username">
<input type="checkbox" id="remeber">记住用户名
<script>
var username = document.querySelector('#username');
var remeber = document.querySelector('#remeber');
//判断有没有数据
if (localStorage.getItem('username')) {
// 有则取
username.value = localStorage.getItem('username');
// 同时勾选复选框
remeber.checked = true;
}
remeber.addEventListener('change', function() {
if (this.checked) {
localStorage.setItem('username', username.value)
} else {
localStorage.removeItem('username');
}
})
</script>
运行结果;