Vue思维导图目录
-
与MVC
的区别MVVM
-
基本代码结构Vue
-
指令Vue
-
组件Vue
-
和class
动态绑定style
-
计算属性computed
-
EventBus
-
过滤器方法filter
Vue
是一套构建用户界面的框架,只关注视图层,它不仅易于上手,还便于与第三方库或既有项目整合。(
Vue
有配套的第三方类库,可以整合起来做大型项目的开发)
![](https://img.laitimes.com/img/__Qf2AjLwojIjJCLyojI0JCLicmbw5SYzM2MmRGM4QWN1IGZjRzYzUzNmRWO4EDZzQGN3QmZ08CX0JXZ252bj91Ztl2Lc52YucWbp5GZzNmLn9Gbi1yZtl2Lc9CX6MHc0RHaiojIsJye.png)
0.MVC 与MVVM的区别
-
是后端的分层开发概念;MVC
-
是前端视图层的概念,主要关注于 视图层分离 。MVVM
把前端的视图层分为了三部分:MVVM
,Model
,View
VM ViewModel
1.Vue基本代码结构
const vm = new Vue({
el:'#app',//所有的挂载元素会被 Vue 生成的 DOM 替换
data:{ // this->window },
methods:{ // this->vm},
//注意,不应该使用箭头函数来定义 method 函数 ,this将不再指向vm实例
props:{} ,// 可以是数组或对象类型,用于接收来自父组件的数据
//对象允许配置高级选项,如类型检测、自定义验证和设置默认值
watch:{ // this->vm},
computed:{},
render(){},
// 声明周期钩子函数
})
当一个
Vue
实例被创建时,它将
data
对象中的所有的
property
加入到
Vue
的响应式系统中。当这些
property
的值发生改变时,视图将会产生
响应,即匹配更新为新的值。
例外:
-
实例外部新增的属性改变时不会更新视图。Vue
-
,会阻止修改现有的Object.freeze()
,响应系统无法追踪其变化。property
实例属性和方法
- 访问
属性:el
,`document.getElemnetById(‘app’)``;vm.$el
- 访问
属性:data
vm.$data
- 以
或_
开头的$
不会被property
实例代理,因为它们可能和Vue
内置的Vue
、property
方法冲突。你可以使用例如API
的方式访问这些vm.$data._property
。property
- 访问
中定义的变量:data
,vm.a
vm.$data.a
- 访问
中的方法:methods
vm.方法名()
- 访问
方法:watch
vm.$watch()
不要在选项
property
或回调上使用箭头函数,
this
将不会指向
Vue
实例 比如
created: () => console.log(this.a)
或
vm.$watch('a', newValue => this.myMethod())
。
因为箭头函数并没有
this
,
this
会作为变量一直向上级词法作用域查找,直至找到为止,经常导致
Uncaught TypeError: Cannot read property of undefined
或
Uncaught TypeError: this.myMethod is not a function
之类的错误。
2. Vue指令
插入数据:
- 插值表达式相当于占位符,不会清空元素中的其他内容。直接写在标签中。会将
标签作为文本显示。html
-
会覆盖元素中原本的内容。写在开始标签中,以属性的形式存在。会将v-text
标签作为文本显示。html
-
会覆盖元素中原本的内容,会将数据解析成v-html(innerHTML)
标签。html
3. Vue组件
组件配置对象和vue实例的区别
- 组件配置对象没有
,组件模板定义在el
中;template
- 组件配置对象中
是函数,该函数返回的对象作为数据。data
创建组件模板
- 方法一
var com = Vue.extend({
//通过template属性 指定组件要展示的html结构
template:'<h3>这是使用Vue.extend搭建的全局组件</h3>'
})
- 方法二:使用对象创建模板
{
template:'<h3>这是使用Vue.extend搭建的全局组件-com3</h3>'
}
- 方法三:使用
标签(写在受控区域外面)创建模板,通过template
建立联系id
<template id="tmpl"> 写在受控区域外面
......
</template>
{ template:'#tmpl' }
组件中的data是一个函数的原因
- 多次使用该组件,如果修改其中一个中的数据,另一个也会改变。
- 写成函数的形式,每次调用函数,返回一个新的对象
ref属性
- 获取
元素/组件:标签上添加dom
属性,ref
属性值获取该this.$refs.ref
。dom元素/组件
-
属性值this.$refs.ref
获取组件中的数据.变量名
-
属性值this.$refs.ref
获取组件中的方法.方法名()
$parent
和 $children
获取 父/子组件的数据和方法
$parent
$children
-
获取父组件this.$parent
-
由于子组件的个数不确定 返回的是一个数组 ,不是对象$children
-
获取第一个子组件this.$children[0]
作用域插槽:父组件替换插槽的标签,内容由子组件决定。
编译的作用域:自身的数据在自身模板 template
标签中生效
- 插槽上添加 属性绑定 :
data=’子组件中的数据’
- 父组件通过
标签,添加template
slot-scope=’slot’
属性接收子组件中的数据slot-scope
slot.data
-
标签中的html结构替换template
插槽中的默认slot
结构。html
4.class和style动态绑定
绑定
5.computed 计算属性
6.EventBus
7.filter过滤器方法
原作者姓名:1024 FED
原出处:腾讯云
原文链接:面试必备 Vue 知识点 - 云+社区 - 腾讯云