小知识,大挑战!本文正在参与“程序员必备小知识”创作活动。
1、tempalte模板中的所有内容要被根节点包含起来。
2、子组件挂载到父组件步骤。 (1)引入子组件 (2)挂载组件 (3)在父组件tempalte模板中使用
3、报错:Elements in iteration expect to have 'v-bind:key' directives迭代中的元素希望有“v-bind:key”指令
(1)方法一:屏蔽ESLint对vue语法的检查。
(2)在v-for后面加上:key="index"就可以了。key的值最好是唯一标识,其实用index也有不好的地方。这方面大家自行百度。
4、报错:vue/no-use-v-if-with-v-for] The 'columns' variable inside 'v-for' directive should be replaced with
同一节点v-for和v-if不能一起使用,因为v-for的优先级比v-if高,意味着v-if 将分别重复运行于每个 v-for 循环中。
(1)情形一:为了过滤一个列表中的项目 (比如 v-for="user in users" v-if="user.isActive")。在这种情形下,请将 users替换为一个计算属性 (比如 activeUsers),让其返回过滤后的列表。
通过将其更换为在如下的一个计算属性上遍历:
(2)情形二:为了避免渲染本应该被隐藏的列表 (比如 v-for="user in users" v-if="shouldShowUsers")。这种情形下,请将 v-if 移动至容器元素上 (比如 ul, ol)。
5、localStorage
vue中实现本地储存的方法:localStorage,在HTML5中,新加入了一个localStorage特性,这个特性主要是用来作为本地存储来使用的,解决了cookie存储空间不足的问题(cookie中每条cookie的存储空间为4k),localStorage中一般浏览器支持的是5M大小,这个在不同的浏览器中localStorage会有所不同。
(1)存储数据
localStorage.setItem('accessToken', 'Bearer ' + response.data.result.accessToken)
(2)取出数据
localStorage.getItem('accessToken')
(3)删除存储数据
localStorage.removeItem('accessToken')
(4)更改数据
localStorage.setItem('accessToken', '更改后' + response.data.result.accessToken)
(5)使用时有几点需要注意过的地方:
- localStorage在浏览器的隐私模式下面是不可读取的。
- localStorage本质上是对字符串的读取,有json格式时需要JSON.stringify()转化为字符串。
- localStorage不能被爬虫抓取到
(6)封装storage
storage.js
//封装操作localstorage本地存储的方法 模块化的文件
var storage={
set(key,value){
localStorage.setItem(key, JSON.stringify(value));
},
get(key){
return JSON.parse(localStorage.getItem(key));
},
remove(key){
localStorage.removeItem(key);
}}
export default storage;
在组件中引入后使用。
6、生命周期函数