总结TodoList案例
1.组件化编码流程:
(1).拆分静态组件:组件要按照功能点拆分,命名不要与html元索冲突.
(2).实现动态组件:考虑好数据的存放位置,数据是一个组件在用, 还是一
些组件在用:
1).一个组件在用:放在组件自身即可。
2). 一些组件在用:放在他们共同的父组件上(状态提升) .
(3).实现交互:从绑定事件开始。
2. props适用于:
(1).父组件==>子组件通信
(2).子组件==>父组件通信(要求父先给子一个函数)
3.使用v-model时要切记: v-model绑定的值不能是props传过来的值,因为props
是不可以修改的!
4. props传过来的若是对象类型的值,修改对象中的属性时Vue不会报错,但不推
荐这样做。
webStorage
1.存储内容大小一般支持5MB左右(不同浏览器可能还不一样)
2.浏览器端通过Window. sessionStorage和Window.localStorage属性来实现本地存储机制。
3.相关API: .
1. xxxStorage.setItem(key', "value°);
该方法接受一个键和值作为参数,会把键值对添加到存储中,如果键名存在,则更新其对应
的值。
2. xxxStorage.getItem( 'person'); !
该方法接受一个键名作为参数,返回键名对应的值。
3. xxxStorage.removeIten('key');
该方法接受一个键名作为参数,并把该键名从存储中删除。
4.xxxxStorage .clear()
该方法会清空存储中的所有数据。
4.备注:
1. SessionStorage存储的内容会随着浏览器密口关闭而消失。
2. LocalStorage存储的内容,需要手动清除才会消失。
3. xxxStorage.getItem(xxx)如xx对应的value获取不到,那么getItem的返回值是null,
4.JSON.parse(null)的结果依然是nul.
LocalStorage.html
<html lang="en">
<head>
<meta charset="UTF-8">
<title>localStorage</title>
<script>
let p = { name: "zzc", age: 18 }
function addDate() {
localStorage.setItem("msg", "msg1")
localStorage.setItem("msg2", "msg2")
localStorage.setItem("person", JSON.stringify(p))
}
function readAllDate() {
console.log(localStorage.getItem("msg"))
console.log(localStorage.getItem("msg2"))
const result = localStorage.getItem("person")
console.log(JSON.parse(result))
}
function deleteDate() {
localStorage.removeItem("msg2")
}
function deleteAllDate() {
localStorage.clear()
}
</script>
</head>
<body>
<h1>localStorage</h1>
<button onclick="addDate()">添加</button>
<button onclick="readAllDate()">查询</button>
<button onclick="deleteDate()">删除</button>
<button onclick="deleteAllDate()">清除</button>
</body>
</html>
SessionStorage.html
<html lang="en">
<head>
<meta charset="UTF-8">
<title>sessionStorage</title>
</head>
<body>
<h1>sessionStorage</h1>
<button onclick="addDate()">添加</button>
<button onclick="readAllDate()">查询</button>
<button onclick="deleteDate()">删除</button>
<button onclick="deleteAllDate()">清除</button>
</body>
<script>
let p={name:"zzc",age:18}
function addDate(){
sessionStorage.setItem("msg","msg1")
sessionStorage.setItem("msg2","msg2")
sessionStorage.setItem("person",JSON.stringify(p))
}
function readAllDate(){
console.log(sessionStorage.getItem("msg"))
console.log(sessionStorage.getItem("msg2"))
const result=sessionStorage.getItem("person")
console.log(JSON.parse(result))
}
function deleteDate(){
sessionStorage.removeItem("msg2")
}
function deleteAllDate(){
sessionStorage.clear()
}
</script>
</html>