vue-vue2脚手架6-浏览器本地存储
其实这边不借助vue就能实现本地存储功能, js有这种功能1. 组件化编码流程:? (1).拆分静态组件:组件要按照功能点拆分,命名不要与html元素冲突。? (2).实现动态组件:考虑好数据的存放位置,数据是一个组件在用,还是一些组件在用:?1).一个组件在用:放在组件自身即可。?2). 一些组件在用:放在他们共同的父组件上(状态提升)。? (3).实现交互:从绑定事件开始。
2. props适用于:? (1).父组件 ==> 子组件 通信? (2).子组件 ==> 父组件 通信(要求父先给子一个函数)3. 使用v-model时要切记:v-model绑定的值不能是props传过来的值,因为props是不可以修改的!4. props传过来的若是对象类型的值,修改对象中的属性时Vue不会报错,但不推荐这样做。
webStorage
- 存储内容大小一般支持5MB左右(不同浏览器可能还不一样)
- 【#|vue-vue2脚手架6-浏览器本地存储webStorage】浏览器端通过 Window.sessionStorage 和 Window.localStorage 属性来实现本地存储机制。
- 相关API:
-
xxxxxStorage.setItem('key', 'value');
该方法接受一个键和值作为参数,会把键值对添加到存储中,如果键名存在,则更新其对应的值。
-
xxxxxStorage.getItem('person');
? 该方法接受一个键名作为参数,返回键名对应的值。
-
xxxxxStorage.removeItem('key');
? 该方法接受一个键名作为参数,并把该键名从存储中删除。
-
xxxxxStorage.clear()
? 该方法会清空存储中的所有数据。
-
- 备注:
- SessionStorage存储的内容会随着浏览器窗口关闭而消失。
- LocalStorage存储的内容,需要手动清除才会消失。
xxxxxStorage.getItem(xxx)
如果xxx对应的value获取不到,那么getItem的返回值是null。JSON.parse(null)
的结果依然是null。
文章图片
localStorage实例 ,sessionStorage 同理
localStorage - 锐客网
localStorage
type="text/javascript" >
let p = {name:'张三',age:18}function saveData(){
localStorage.setItem('msg','hello!!!')
localStorage.setItem('msg2',666)
localStorage.setItem('person',JSON.stringify(p))
}
function readData(){
console.log(localStorage.getItem('msg'))
console.log(localStorage.getItem('msg2'))const result = localStorage.getItem('person')
console.log(JSON.parse(result))// console.log(localStorage.getItem('msg3'))
}
function deleteData(){
localStorage.removeItem('msg2')
}
function deleteAllData(){
localStorage.clear()
}
关于todolist的存储
可以使用watch 监听方法来实现该功能
- 这里是要开启深度监听的,如果watch监听到事件改变了,vue是无法监听到地址值的改变,所以要开启 deep:true,
>
import MyHeader from './components/MyHeader'
import MyList from './components/MyList'
import MyFooter from './components/MyFooter.vue' export default {
name:'App',
components:{MyHeader,MyList,MyFooter},
data() {
return {
//由于todos是MyHeader组件和MyFooter组件都在使用,所以放在App中(状态提升)
todos:JSON.parse(localStorage.getItem('todos')) || []
}
},
methods: {
//添加一个todo
addTodo(todoObj){
this.todos.unshift(todoObj)
},
//勾选or取消勾选一个todo
checkTodo(id){
this.todos.forEach((todo)=>{
if(todo.id === id) todo.done = !todo.done
})
},
//删除一个todo
deleteTodo(id){
this.todos = this.todos.filter( todo => todo.id !== id )
},
//全选or取消全选
checkAllTodo(done){
this.todos.forEach((todo)=>{
todo.done = done
})
},
//清除所有已经完成的todo
clearAllTodo(){
this.todos = this.todos.filter((todo)=>{
return !todo.done
})
}
},
watch: {
todos:{
// 开启深度监听
deep:true,
handler(value){
localStorage.setItem('todos',JSON.stringify(value))
}
}
},
}
推荐阅读
- JavaScript|Vue 04 生命周期 组件化 内置关系 Vue脚手架 render函数 ref属性 _props配置 mixin混入 插件 scoped样式
- TypeScript|【TypeScript基础】TypeScript之常用类型(下)
- Vue|vue - props配置项\ mixin\插件\scoped
- Axios及网络基础|猿创征文|Axios的介绍与作用 - 大白话
- 笔记|WebGIS前端学习之路(Vue+Leaflet地图展示)
- uni-app|uniapp加载leaflet地图
- uniapp|uniapp中引入使用leaflet地图
- #|电力系统的延时功率流 (CPF)的计算【 IEEE-14节点】(Matlab代码实现)
- vue|vue中用ref实现父子组件、孙组件、兄弟组件、非亲子孙组件互相调用的方法