【前端词典】Vue 使用时常见的 5 个问题
前言
今天分享 5 个你或许在使用 Vue 开发过程中也遇到的问题。
Vue 使用时常见的 5 个问题
自定义路径别名
可能有些人注意到了,在 vue-cli 生成的模板中在导入组件时使用了这样的语法:
import Index from '@/components/Index'
这个 @ 是什么东西?后来改配置文件的时候发现这个是 webpack 的配置选项之一:路径别名。
我们也可以在基础配置文件中添加自己的路径别名,比如下面这个就把 ~ 设置为路径 src/components
的别名:
// build/webpack.base.js{ resolve: { extensions: ['.js', '.vue', '.json'], alias: { 'vue$': 'vue/dist/vue.esm.js', '@': resolve('src'), '~': resolve('src/components') } }}
然后我们导入组件的时候就可以这样写:
// import YourComponent from '/src/components/YourComponent'import YourComponent from '~/YourComponent'
既解决了路径过长的麻烦,又解决了相对路径的烦恼,方便很多吧!
CSS 作用域与模块
组件内样式
通常,组件中 <style></style>
标签里的样式是全局的,在使用第三方 UI 库(如:Element)时,全局样式很可能影响 UI 库的样式。
我们可以通过添加 scoped
属性来使 style
中的样式只作用于当前组件:
<style lang="less" scoped> @import 'other.less'; .title { font-size: 1.2rem; }</style>
在有 scoped
属性的 style
标签内导入其他样式,同样会受限于作用域,变为组件内样式。复用程度较高的样式不建议这样使用。
导入样式
相对于 style
使用 scoped
属性时的组件内样式,有时候我们也需要添加一些全局样式。当然我们可以用没有 scoped
属性的 style
来写全局样式。
但是相比较,更推荐下面这种写法:
/* 单独的全局样式文件 *//* style-global.less */body { font-size: 10px;}.title { font-size: 1.4rem; font-weight: bolder;}
然后在入口文件中导入全局样式:
// src/main.jsimport 'style-global.less'
v-for 的使用 tips
v-for
指令很强大,它不仅可以用来遍历数组、对象,甚至可以遍历一个数字或字符串。
基本语法就不讲了,这里讲个小 tips:
索引值
在使用 v-for
根据对象或数组生成 DOM 时,有时候需要知道当前的索引。我们可以这样:
<ul> <li v-for='(item, key) in items' :key='key'> {{ key }} - {{ item }}</ul>
但是,在遍历数字的时候需要注意,数字的 value 是从 1 开始,而 key 是从 0 开始:
<ul> <li v-for='(v, k) in 3' :key='k'> {{ k }}-{{ v }}</ul>
2.2.0+ 的版本里,当在组件中使用 v-for 时,key 现在是必须的。
vue 中 this 指向问题
method 不能使用箭头函数
因为箭头函数绑定了父级作用域的上下文,所以 this 将不会按照期望指向 Vue 实例。
const App = new Vue({ el: 'body', methods: { foo: () => { console.log(this) // undefined } }})const App = new Vue({ el: 'body', methods: { foo () { console.log(this) // Vue instance } }})
method 中方法使用定时器需要使用箭头函数
箭头函数中的this指向是固定不变的,即是在定义函数时的指向 而普通函数中的this指向时变化的,即是在使用函数时的指向
箭头函数代码:
methods: { goPage: function (index) { this.newPage = index }, inv: function () { this.invt = setInterval(() => { this.goPage(this.nextPage) console.log(this) //此时的this指向是该vue组件,不管在哪使用,指向都是该vue组件 }, 1000) }}
普通函数的代码:
methods: { goPage: function (index) { this.newPage = index }, inv: function () { this.invt = setInterval(function () { this.goPage(this.nextPage) console.log(this) //此时的this并不是该vue组件,而是指向window。 }, 1000) }}
setInterval() 与 setTimeout() 是 window 对象的函数,所以 this 会指向 window
一个 template 模板只能有一个可渲染的子元素
一个 <template>
下面只能有一个可渲染的子元素否则会报错, 报错如下:
即:
<template> <h1>Title</h1> <p>Balabala...</p> <p>Balabala...</p></template>
// 应该为<template> <div> <h1>Title</h1> <p>Balabala...</p> <p>Balabala...</p> </div></template>
- android 自定义gallerey并实现预览功能
- Android学习第五弹之Matrix的用法
- 推荐一款超强大的基于Angularjs的自动完成(Autocomplete)标签及标签组插件–ngTagsInput
- Android新组件RecyclerView介绍,其效率更好
- android wheelview实现三级城市选择
- 算法之冒泡排序
- 数据结构之链表
- Spring Cloud实战小贴士:Zuul统一异常处理(三)【Dalston版】
- 算法之红黑树
- MIDlet工作原理
- 第五章 正则表达式的拆分【修订】
- 仿今天头条加载环境文字闪动效果
- Myexclipse创建Junit测试
- 基于ASP.NET MVC(C#)和Quartz.Net组件实现的定时执行任务调度
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- maven初步入门
- 超详细的Java弹窗样式及使用教程【JOptionPane类详细使用教程】
- Python 技术篇-用PIL库旋转图片的两种方式,改变图像尺寸
- html+css+JavaScript例题
- 加速Github的访问及下载速度
- HDFS简介
- Python 技术篇-获取requests里的二进制文本并保存为音频、图片文件
- [转]maven的pom.xml详解
- Windows下给磁盘扩容
- ZooKeeper的安装
- 仿微信的网络聊天室项目开发【完整源码讲解】
- Chrome 小技巧
- 梳理Java IO流,攻破NIO的堡垒!【技术创作101训练营】
- hadoop2.6.0-HA-QJM
- hadoop常用维护命令