目录

导读

1. Vue的优缺点

2. Vue是渐进式框架

3. Vue跟React的异同点?

相同点:

不同点:

4. MVVM是什么?和MVC有何区别呢?

MVC

MVVM

区别

5. Vue和JQuery的区别在哪?为什么放弃JQuery用Vue?

6.Vue的作者

7. 为什么data是个函数并且返回一个对象呢?

8. 使用过哪些Vue的修饰符呢?

9. 使用过哪些Vue的内部指令呢?

1. v-text

2. v-html

3. v-pre

4. v-cloak

5. v-once

6. v-if

7. v-else

8. v-else-if

9. v-show

10. v-for

11. v-bind

12. v-model

10. 组件之间的传值方式有哪些?

11. 路由有哪些模式呢?又有什么不同呢?

12. 如何设置动态class,动态style?

13. v-if和v-show有何区别?

14. computed和watch有何区别?

15. Vue的生命周期

16. 为什么v-if和v-for不建议用在同一标签?

17. vuex的有哪些属性?用处是什么?

18. 不需要响应式的数据应该怎么处理?

19. watch有哪些属性,分别有什么用?

20. 父子组件生命周期顺序

21. 对象新属性无法更新视图,删除属性无法更新视图,为什么?怎么办?

22. 直接arr[index] = xxx无法更新视图怎么办?为什么?怎么办?

23. 自定义指令

24. 插槽的使用以及原理?

25. 为什么不建议用index做key,为什么不建议用随机数做key?

26. 说说nextTick的用处?

27. Vue的SSR是什么?有什么好处?

28. Vue响应式是怎么实现的?

29. 为什么只对对象劫持,而要对数组进行方法重写?

30.Vue.set方法的原理?

31.props怎么自定义验证

32. watch监听一个对象时,如何排除某些属性的监听

33. computed如何实现传参?

34. vue的hook的使用

35. provide和inject是响应式的吗?

36.Vue的el属性和$mount优先级?

37. 动态指令和参数使用过吗?

38. 相同的路由组件如何重新渲染?

39. 自定义v-model

40. 如何将获取data中某一个数据的初始状态?

41.为什么不建议v-for和v-if同时存在

42.计算变量时,methods和computed哪个好?


导读

每个IT开发者都希望自己成为大神,尤其是最近几年流行的vue、react、Angular前端三大框架,大大加快了前端开发者的开发速度,几乎是革命性的改变!而vue框架是现在最火热的,也是使用人数最多的框架,全面的掌握它,便能在成为大神的道路上更进一步。以下是我总结的几乎所有的vue的知识:

1. Vue的优缺点

优点:渐进式,组件化,轻量级,虚拟dom,响应式,单页面路由,数据与视图分开

缺点:单页面不利于seo,不支持IE8以下,首屏加载时间长

2. Vue是渐进式框架

渐进式:通俗点讲就是,你想用啥你就用啥,咱也不强求你。你想用component就用,不用也行,你想用vuex就用,不用也可以

3. Vue跟React的异同点?

相同点:

1.都使用了虚拟dom
2.组件化开发
3.都是单向数据流(父子组件之间,不建议子修改父传下来的数据)
4.都支持服务端渲染

不同点:

1.React的JSX,Vue的template
2.数据变化,React手动(setState),Vue自动(初始化已响应式处理,Object.defineProperty)
3.React单向绑定,Vue双向绑定
4.React的Redux,Vue的Vuex

4. MVVM是什么?和MVC有何区别呢?

MVC

Model(模型):负责从数据库中取数据
View(视图):负责展示数据的地方
Controller(控制器):用户交互的地方,例如点击事件等等
思想:Controller将Model的数据展示在View上

MVVM

VM:也就是View-Model,做了两件事达到了数据的双向绑定 一是将【模型】转化成【视图】,即将后端传递的数据转化成所看到的页面。实现的方式是:数据绑定。二是将【视图】转化成【模型】,即将所看到的页面转化成后端的数据。实现的方式是:DOM 事件监听。
思想:实现了 View 和 Model 的自动同步,也就是当 Model 的属性改变时,我们不用再自己手动操作 Dom 元素,来改变 View 的显示,而是改变属性后该属性对应 View 层显示会自动改变(对应Vue数据驱动的思想)

区别

整体看来,MVVM 比 MVC 精简很多,不仅简化了业务与界面的依赖,还解决了数据频繁更新的问题,不用再用选择器操作 DOM 元素。因为在 MVVM 中,View 不知道 Model 的存在,Model 和 ViewModel 也观察不到 View,这种低耦合模式提高代码的可重用性

Vue是MVVM框架,但是不是严格符合MVVM,因为MVVM规定Model和View不能直接通信,而Vue的ref可以做到这点。

5. Vue和JQuery的区别在哪?为什么放弃JQuery用Vue?

  • jQuery是直接操作DOM,Vue不直接操作DOM,Vue的数据与视图是分开的,Vue只需要操作数据即可
  • 在操作DOM频繁的场景里,jQuery的操作DOM行为是频繁的,而Vue利用虚拟DOM的技术,大大提高了更新DOM时的性能
  • Vue中不倡导直接操作DOM,开发者只需要把大部分精力放在数据层面上
  • Vue集成的一些库,大大提高开发效率,比如Vuex,Router等

6.Vue的作者

尤雨溪

7. 为什么data是个函数并且返回一个对象呢?

data之所以只一个函数,是因为一个组件可能会多处调用,而每一次调用就会执行data函数并返回新的数据对象,这样,可以避免多处调用之间的数据污染。

8. 使用过哪些Vue的修饰符呢?

9. 使用过哪些Vue的内部指令呢?

1. v-text

v-text主要用来更新textContent,可以等同于JS的text属性。

<span v-text="msg"></span>

这两者等价:

<span>{{msg}}</span>

2. v-html

双大括号的方式会将数据解释为纯文本,而非HTML。为了输出真正的HTML,可以用v-html指令。它等同于JS的innerHtml属性。

<div v-html="rawHtml"></div>

这个div的内容将会替换成属性值rawHtml,直接作为HTML进行渲染。

3. v-pre

v-pre主要用来跳过这个元素和它的子元素编译过程。可以用来显示原始的Mustache标签。跳过大量没有指令的节点加快编译。

<div id="app"><span v-pre>{{message}}</span>  //这条语句不进行编译<span>{{message}}</span>
</div>

最终仅显示第二个span的内容

4. v-cloak

这个指令是用来保持在元素上直到关联实例结束时进行编译。

<div id="app" v-cloak><div>{{message}}</div>
</div>
<script type="text/javascript">new Vue({el:'#app',data:{message:'hello world'}})
</script>

在页面加载时会闪烁,先显示:

<div>{{message}}
</div>

然后才会编译为:

<div>hello world!
</div>

5. v-once

v-once关联的实例,只会渲染一次。之后的重新渲染,实例极其所有的子节点将被视为静态内容跳过,这可以用于优化更新性能。

<span v-once>This will never change:{{msg}}</span>  //单个元素
<div v-once>//有子元素<h1>comment</h1><p>{{msg}}</p>
</div>
<my-component v-once:comment="msg"></my-component>  //组件
<ul><li v-for="i in list">{{i}}</li>
</ul>

上面的例子中,msg,list即使产生改变,也不会重新渲染。

6. v-if

v-if可以实现条件渲染,Vue会根据表达式的值的真假条件来渲染元素。

<a v-if="ok">yes</a>

如果属性值ok为true,则显示。否则,不会渲染这个元素。

7. v-else

v-else是搭配v-if使用的,它必须紧跟在v-if或者v-else-if后面,否则不起作用。

<a v-if="ok">yes</a>
<a v-else>No</a>

8. v-else-if

v-else-if充当v-if的else-if块,可以链式的使用多次。可以更加方便的实现switch语句。

<div v-if="type==='A'">A
</div>
<div v-else-if="type==='B'">B
</div>
<div v-else-if="type==='C'">C
</div>
<div v-else>Not A,B,C
</div>

9. v-show

<h1 v-show="ok">hello world</h1>

也是用于根据条件展示元素。和v-if不同的是,如果v-if的值是false,则这个元素被销毁,不在dom中。但是v-show的元素会始终被渲染并保存在dom中,它只是简单的切换css的dispaly属性。

注意:v-if有更高的切换开销
v-show有更高的初始渲染开销。
因此,如果要非常频繁的切换,则使用v-show较好;如果在运行时条件不太可能改变,则v-if较好

10. v-for

用v-for指令根据遍历数组来进行渲染
有下面两种遍历形式

<div v-for="(item,index) in items"></div>   //使用in,index是一个可选参数,表示当前项的索引
<div v-for="item of items"></div>   //使用of

下面是一个例子,并且在v-for中,拥有对父作用域属性的完全访问权限。

<ul id="app"><li v-for="item in items">{{parent}}-{{item.text}}</li>
</ul>
<script type="text/javascript">var example = new Vue({el:'#app',data:{parent:'父作用域'items:[{text:'文本1'},{text:'文本2'}]}})
</script>

会被渲染为:

<ul id="app"><li>父作用域-文本1</li><li>父作用域-文本2</li>
</ul>

注意:当v-for和v-if同处于一个节点时,v-for的优先级比v-if更高。这意味着v-if将运行在每个v-for循环中

11. v-bind

v-bind用来动态的绑定一个或者多个特性。没有参数时,可以绑定到一个包含键值对的对象。常用于动态绑定class和style。以及href等。
简写为一个冒号【 :】

<1>对象语法:

//进行类切换的例子
<div id="app"><!--当data里面定义的isActive等于true时,is-active这个类才会被添加起作用--><!--当data里面定义的hasError等于true时,text-danger这个类才会被添加起作用--><div :class="{'is-active':isActive, 'text-danger':hasError}"></div>
</div>
<script>var app = new Vue({el: '#app',data: {isActive: true,  hasError: false}})
</script>

渲染结果:

<!--因为hasError: false,所以text-danger不被渲染-->
<div class = "is-active"></div>

<2>数组语法

<div id="app"><!--数组语法:errorClass在data对应的类一定会添加--><!--is-active是对象语法,根据activeClass对应的取值决定是否添加--><p :class="[{'is-active':activeClass},errorClass]">12345</p>
</div>
<script>var app = new Vue({el: '#app',data: {activeClass: false,errorClass: 'text-danger'}})
</script>

渲染结果:

<!--因为activeClass: false,所以is-active不被渲染-->
<p class = "text-danger"></p>

<3>直接绑定数据对象

<div id="app"><!--在vue实例的data中定义了classObject对象,这个对象里面是所有类名及其真值--><!--当里面的类的值是true时会被渲染--><div :class="classObject">12345</div>
</div>
<script>var app = new Vue({el: '#app',data: {classObject:{'is-active': false,'text-danger':true}           }})
</script>

渲染结果:

<!--因为'is-active': false,所以is-active不被渲染-->
<div class = "text-danger"></div>

12. v-model

这个指令用于在表单上创建双向数据绑定。
v-model会忽略所有表单元素的value、checked、selected特性的初始值。因为它选择Vue实例数据做为具体的值。

<div id="app"><input v-model="somebody"><p>hello {{somebody}}</p>
</div>
<script>var app = new Vue({el: '#app',data: {somebody:'小明'}})
</script>

这个例子中直接在浏览器input中输入别的名字,下面的p的内容会直接跟着变。这就是双向数据绑定。

10. 组件之间的传值方式有哪些?

  • 父组件传值给子组件,子组件使用props进行接收
  • 子组件传值给父组件,子组件使用$emit+事件对父组件进行传值
  • 组件中可以使用$parent和$children获取到父组件实例和子组件实例,进而获取数据
  • 使用$attrs和$listeners,在对一些组件进行二次封装时可以方便传值,例如A->B->C
  • 使用$refs获取组件实例,进而获取数据
  • 使用Vuex进行状态管理
  • 使用eventBus进行跨组件触发事件,进而传递数据
  • 使用provide和inject,官方建议我们不要用这个,我在看ElementUI源码时发现大量使用
  • 使用浏览器本地缓存,例如localStorage

11. 路由有哪些模式呢?又有什么不同呢?

  • hash模式:通过#号后面的内容的更改,触发hashchange事件,实现路由切换
  • history模式:通过pushState和replaceState切换url,触发popstate事件,实现路由切换,需要后端配合

12. 如何设置动态class,动态style?

  • 动态class对象:<div :class="{ 'is-active': true, 'red': isRed }"></div>
  • 动态class数组:<div :class="['is-active', isRed ? 'red' : '' ]"></div>
  • 动态style对象:<div :style="{ color: textColor, fontSize: '18px' }"></div>
  • 动态style数组:<div :style="[{ color: textColor, fontSize: '18px' }, { fontWeight: '300' }]"></div>

13. v-if和v-show有何区别?

  • v-if是通过控制dom元素的删除和生成来实现显隐,每一次显隐都会使组件重新跑一遍生命周期,因为显隐决定了组件的生成和销毁
  • v-show是通过控制dom元素的css样式来实现显隐,不会销毁
  • 频繁或者大数量显隐使用v-show,否则使用v-if

14. computed和watch有何区别?

  • computed是依赖已有的变量来计算一个目标变量,大多数情况都是多个变量凑在一起计算出一个变量,并且computed具有缓存机制,依赖值不变的情况下其会直接读取缓存进行复用,computed不能进行异步操作
  • watch是监听某一个变量的变化,并执行相应的回调函数,通常是一个变量的变化决定多个变量的变化,watch可以进行异步操作
  • 简单记就是:一般情况下computed是多对一,watch是一对多

15. Vue的生命周期

16. 为什么v-if和v-for不建议用在同一标签?

在Vue2中,v-for优先级是高于v-if的,咱们来看例子

<div v-for="item in [1, 2, 3, 4, 5, 6, 7]" v-if="item !== 3">{{item}}
</div>

上面的写法是v-forv-if同时存在,会先把7个元素都遍历出来,然后再一个个判断是否为3,并把3给隐藏掉,这样的坏处就是,渲染了无用的3节点,增加无用的dom操作,建议使用computed来解决这个问题:

<div v-for="item in list">{{item}}
</div>computed() {list() {return [1, 2, 3, 4, 5, 6, 7].filter(item => item !== 3)}}

17. vuex的有哪些属性?用处是什么?

  • State:定义了应用状态的数据结构,可以在这里设置默认的初始状态。
  • Getter:允许组件从 Store 中获取数据,mapGetters 辅助函数仅仅是将 store 中的 getter 映射到局部计算属性。
  • Mutation:是唯一更改 store 中状态的方法,且必须是同步函数。
  • Action:用于提交 mutation,而不是直接变更状态,可以包含任意异步操作。
  • Module:允许将单一的 Store 拆分为多个 store 且同时保存在单一的状态树中。

18. 不需要响应式的数据应该怎么处理?

在我们的Vue开发中,会有一些数据,从始至终都未曾改变过,这种死数据,既然不改变,那也就不需要对他做响应式处理了,不然只会做一些无用功消耗性能,比如一些写死的下拉框,写死的表格数据,这些数据量大的死数据,如果都进行响应式处理,那会消耗大量性能。

// 方法一:将数据定义在data之外
data () {this.list1 = { xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx }this.list2 = { xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx }this.list3 = { xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx }this.list4 = { xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx }this.list5 = { xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx }return {}}// 方法二:Object.freeze()
data () {return {list1: Object.freeze({xxxxxxxxxxxxxxxxxxxxxxxx}),list2: Object.freeze({xxxxxxxxxxxxxxxxxxxxxxxx}),list3: Object.freeze({xxxxxxxxxxxxxxxxxxxxxxxx}),list4: Object.freeze({xxxxxxxxxxxxxxxxxxxxxxxx}),list5: Object.freeze({xxxxxxxxxxxxxxxxxxxxxxxx}),}}

19. watch有哪些属性,分别有什么用?

当我们监听一个基本数据类型时:

watch: {value () {// do something}
}

当我们监听一个引用数据类型时:

watch: {obj: {handler () { // 执行回调// do something},deep: true, // 是否进行深度监听immediate: true // 是否初始执行handler函数}
}

20. 父子组件生命周期顺序

父beforeCreate -> 父created -> 父beforeMount -> 子beforeCreate -> 子created -> 子beforeMount -> 子mounted -> 父mounted

21. 对象新属性无法更新视图,删除属性无法更新视图,为什么?怎么办?

  • 原因:Object.defineProperty没有对对象的新属性进行属性劫持
  • 对象新属性无法更新视图:使用Vue.$set(obj, key, value),组件中this.$set(obj, key, value)
  • 删除属性无法更新视图:使用Vue.$delete(obj, key),组件中this.$delete(obj, key)

22. 直接arr[index] = xxx无法更新视图怎么办?为什么?怎么办?

  • 原因:Vue没有对数组进行Object.defineProperty的属性劫持,所以直接arr[index] = xxx是无法更新视图的
  • 使用数组的splice方法,arr.splice(index, 1, item)
  • 使用Vue.$set(arr, index, value)

23. 自定义指令

详细查看最常用的几个Vue自定义指令

24. 插槽的使用以及原理?

详细请查看教您怎么使用vue的插槽

25. 为什么不建议用index做key,为什么不建议用随机数做key?

举个例子:

<div v-for="(item, index) in list" :key="index">{{item.name}}</div>list: [{ name: '小明', id: '123' },{ name: '小红', id: '124' },{ name: '小花', id: '125' }
]渲染为
<div key="0">小明</div>
<div key="1">小红</div>
<div key="2">小花</div>现在我执行 list.unshift({ name: '小林', id: '122' })渲染为
<div key="0">小林</div>
<div key="1">小明</div>
<div key="2">小红</div>
<div key="3">小花</div>新旧对比<div key="0">小明</div>  <div key="0">小林</div>
<div key="1">小红</div>  <div key="1">小明</div>
<div key="2">小花</div>  <div key="2">小红</div><div key="3">小花</div>可以看出,如果用index做key的话,其实是更新了原有的三项,并新增了小花,虽然达到了渲染目的,但是损耗性能现在我们使用id来做key,渲染为<div key="123">小明</div>
<div key="124">小红</div>
<div key="125">小花</div>现在我执行 list.unshift({ name: '小林', id: '122' }),渲染为<div key="122">小林</div>
<div key="123">小明</div>
<div key="124">小红</div>
<div key="125">小花</div>新旧对比<div key="122">小林</div>
<div key="123">小明</div>  <div key="123">小明</div>
<div key="124">小红</div>  <div key="124">小红</div>
<div key="125">小花</div>  <div key="125">小花</div>可以看出,原有的三项都不变,只是新增了小林这个人,这才是最理想的结果

用index和用随机数都是同理,随机数每次都在变,做不到专一性,很渣男,也很消耗性能,所以,拒绝渣男,选择老实人

26. 说说nextTick的用处?

举个例子,在vue中:

this.name = '林三心'
this.age = 18
this.gender = '男'

我们修改了三个变量,那问题来了,是每修改一次,DOM就更新一次吗?不是的,Vue采用的是异步更新的策略,通俗点说就是,同一事件循环内多次修改,会统一进行一次视图更新,这样才能节省性能嘛

看懂了上面,那你应该也看得懂下面的例子了吧:

<div ref="testDiv">{{name}}</div>name: '小林'this.name = '林三心'
console.log(this.$refs.testDiv.innerHTML) // 这里是啥呢

答案是“小林”,前面说了,Vue是异步更新,所以数据一更新,视图却还没更新,所以拿到的还是上一次的旧视图数据,那么想要拿到最新视图数据怎么办呢?

this.name = '林三心'
this.$nextTick(() => {console.log(this.$refs.testDiv.innerHTML) // 林三心
})

27. Vue的SSR是什么?有什么好处?

  • SSR就是服务端渲染
  • 基于nodejs serve服务环境开发,所有html代码在服务端渲染
  • 数据返回给前端,然后前端进行“激活”,即可成为浏览器识别的html代码
  • SSR首次加载更快,有更好的用户体验,有更好的seo优化,因为爬虫能看到整个页面的内容,如果是vue项目,由于数据还要经过解析,这就造成爬虫并不会等待你的数据加载完成,所以其实Vue项目的seo体验并不是很好

28. Vue响应式是怎么实现的?

整体思路是数据劫持+观察者模式
对象内部通过 defineReactive 方法,使用 Object.defineProperty 将属性进行劫持(只会劫持已经存在的属性),数组则是通过重写数组方法来实现。当页面使用对应属性时,每个属性都拥有自己的dep属性,存放他所依赖的 watcher(依赖收集),当属性变化后会通知自己对应的 watcher 去更新(派发更新)。

const { arrayMethods } = require('./array')class Observer {constructor(value) {Object.defineProperty(value, '__ob__', {value: this,enumerable: false,writable: true,configurable: true})if(Array.isArray(value)) {value.__proto__ = arrayMethodsthis.observeArray(value)} else {this.walk(value)}}walk(data) {let keys = Object.keys(data)for(let i = 0; i < keys.length; i++) {const key = keys[i]const value = data[key]defineReactive(data, key, value)}}observeArray(items) {for(let i = 0; i < items.length; i++) {observe(items[i])}}
}function defineReactive(data, key, value) {const childOb = observe(value)const dep = new Dep()Object.defineProperty(data, key, {get() {console.log('获取值')if (Dep.target) {dep.depend()if (childOb) {childOb.dep.depend()if (Array.isArray(value)) {dependArray(value)}}}return value},set(newVal) {if (newVal === value) returnobserve(newVal)value = newValdep.notify()}})
}function observe(value) {if (Object.prototype.toString.call(value) === '[object Object]' || Array.isArray(value)) {return new Observer(value)}
}function dependArray(value) {for(let e, i = 0, l = value.length; i < l; i++) {e = value[i]e && e.__ob__ && e.__ob__.dep.depend()if (Array.isArray(e)) {dependArray(e)}}
}// array.js
const arrayProto = Array.prototypeconst arrayMethods = Object.create(arrayProto)const methodsToPatch = ['push','pop','shift','unshift','splice','reverse','sort'
]methodsToPatch.forEach(method => {arrayMethods[method] = function (...args) {const result = arrayProto[method].apply(this, args)const ob = this.__ob__var insertedswitch (method) {case 'push':case 'unshift':inserted = argsbreak;case 'splice':inserted = args.slice(2)default:break;}if (inserted) ob.observeArray(inserted)ob.dep.notify()return result}
})

29. 为什么只对对象劫持,而要对数组进行方法重写?

因为对象最多也就几十个属性,拦截起来数量不多,但是数组可能会有几百几千项,拦截起来非常耗性能,所以直接重写数组原型上的方法,是比较节省性能的方案

30.Vue.set方法的原理?

function set(target, key, val) {// 判断是否是数组if (Array.isArray(target)) {// 判断谁大谁小target.length = Math.max(target.length, key)// 执行splicetarget.splice(key, 1, val)return val}const ob = target.__ob__// 如果此对象没有不是响应式对象,直接设置并返回if (key in target && !(key in target.prototype) || !ob) {target[key] = valreturn val}// 否则,新增属性,并响应式处理defineReactive(target, key, val)return val
}

31.props怎么自定义验证

props: {num: {default: 1,validator: function (value) {// 返回值为true则验证不通过,报错return [1, 2, 3, 4, 5].indexOf(value) !== -1}}}

32. watch监听一个对象时,如何排除某些属性的监听

下面代码是,params发生改变就重新请求数据,无论是a,b,c,d属性改变

data() {return {params: {a: 1,b: 2,c: 3,d: 4},};},
watch: {params: {deep: true,handler() {this.getList;},},}

但是如果我只想要a,b改变时重新请求,c,d改变时不重新请求呢?

mounted() {Object.keys(this.params).filter((_) => !["c", "d"].includes(_)) // 排除对c,d属性的监听.forEach((_) => {this.$watch((vm) => vm.params[_], handler, {deep: true,});});},
data() {return {params: {a: 1,b: 2,c: 3,d: 4},};},
watch: {params: {deep: true,handler() {this.getList;},},}

33. computed如何实现传参?

// html
<div>{{ total(3) }}// js
computed: {total() {return function(n) {return n * this.num}},}

34. vue的hook的使用

  • 同一组件中使用

这是我们常用的使用定时器的方式

export default{data(){timer:null  },mounted(){this.timer = setInterval(()=>{//具体执行内容console.log('1');},1000);}beforeDestory(){clearInterval(this.timer);this.timer = null;}
}

上面做法不好的地方在于:得全局多定义一个timer变量,可以使用hook这么做:

export default{methods:{fn(){let timer = setInterval(()=>{//具体执行代码console.log('1');},1000);this.$once('hook:beforeDestroy',()=>{clearInterval(timer);timer = null;})}}
}
  • 父子组件使用

如果子组件需要在mounted时触发父组件的某一个函数,平时都会这么写:

//父组件
<rl-child @childMounted="childMountedHandle"
/>
method () {childMountedHandle() {// do something...}
},// 子组件
mounted () {this.$emit('childMounted')
},

使用hook的话可以更方便:

//父组件
<rl-child @hook:mounted="childMountedHandle"
/>
method () {childMountedHandle() {// do something...}
},

35. provide和inject是响应式的吗?

// 祖先组件
provide(){return {// keyName: { name: this.name }, // value 是对象才能实现响应式,也就是引用类型keyName: this.changeValue // 通过函数的方式也可以[注意,这里是把函数作为value,而不是this.changeValue()]// keyName: 'test' value 如果是基本类型,就无法实现响应式}},
data(){return {name:'张三'
}},methods: {changeValue(){this.name = '改变后的名字-李四'}}  // 后代组件inject:['keyName']create(){console.log(this.keyName) // 改变后的名字-李四
}

36.Vue的el属性和$mount优先级?

比如下面这种情况,Vue会渲染到哪个节点上

new Vue({router,store,el: '#app',render: h => h(App)
}).$mount('#ggg')

这是官方的一张图,可以看出el和$mount同时存在时,el优先级 > $mount

37. 动态指令和参数使用过吗?

<template>...<aButton @[someEvent]="handleSomeEvent()" :[someProps]="1000" />...
</template>
<script>...data(){return{...someEvent: someCondition ? "click" : "dbclick",someProps: someCondition ? "num" : "price"}},methods: {handleSomeEvent(){// handle some event}}
</script>

38. 相同的路由组件如何重新渲染?

开发人员经常遇到的情况是,多个路由解析为同一个Vue组件。问题是,Vue出于性能原因,默认情况下共享组件将不会重新渲染,如果你尝试在使用相同组件的路由之间进行切换,则不会发生任何变化。

const routes = [{path: "/a",component: MyComponent},{path: "/b",component: MyComponent},
];

如果依然想重新渲染,怎么办呢?可以使用key

<template><router-view :key="$route.path"></router-view>
</template>

39. 自定义v-model

默认情况下,v-model 是 @input 事件侦听器和 :value 属性上的语法糖。但是,你可以在你的Vue组件中指定一个模型属性来定义使用什么事件和value属性——非常棒!

export default: {model: {event: 'change',prop: 'checked'  }
}

40. 如何将获取data中某一个数据的初始状态?

在开发中,有时候需要拿初始状态去计算。例如

data() {return {num: 10},
mounted() {this.num = 1000},
methods: {howMuch() {// 计算出num增加了多少,那就是1000 - 初始值// 可以通过this.$options.data().xxx来获取初始值console.log(1000 - this.$options.data().num)}}

41.为什么不建议v-for和v-if同时存在

<div v-for="item in [1, 2, 3, 4, 5, 6, 7]" v-if="item !== 3">{{item}}
</div>

上面的写法是v-for和v-if同时存在,会先把7个元素都遍历出来,然后再一个个判断是否为3,并把3给隐藏掉,这样的坏处就是,渲染了无用的3节点,增加无用的dom操作,建议使用computed来解决这个问题:

<div v-for="item in list">{{item}}
</div>computed() {list() {return [1, 2, 3, 4, 5, 6, 7].filter(item => item !== 3)}}

42.计算变量时,methods和computed哪个好?

<div><div>{{howMuch1()}}</div><div>{{howMuch2()}}</div><div>{{index}}</div>
</div>data: () {return {index: 0}}
methods: {howMuch1() {return this.num + this.price}}
computed: {howMuch2() {return this.num + this.price}}

computed会好一些,因为computed会有缓存。例如index由0变成1,那么会触发视图更新,这时候methods会重新执行一次,而computed不会,因为computed依赖的两个变量num和price都没变。

vue精通之路:掌握这42个Vue知识点,你将成为大shen相关推荐

  1. vue动态路由加载组件,找不到module问题

    vue动态路由加载组件,找不到module问题 vue动态加载路由并挂载到vue.路由信息由后端给出,同时component的路径也是后端给出,但是动态加载该路径会报错. 原因:webpack 编译e ...

  2. 德国Vue.js2终极开发教程(含Vue路由和Vuex)-Max-专题视频课程

    德国Vue.js2终极开发教程(含Vue路由和Vuex)-808人已学习 课程介绍         新手入门现代前端开发的不二选择 课程目标: * 学会从简单到复杂企业级应用的VueJS程序编写方法 ...

  3. 《Vue入门到精通》最强Vue教程,附带经典案例,万字详解,干货十足!

    目录: 一.前言 二.Vue是什么? 1.简介 2.发展史 3.为什么要学习Vue? 4.jQuery.javascript.Vue的区别 5.Vue框架构造 三.Vue的使用 1.Vue环境搭建 2 ...

  4. vue和react哪个开发效率高,vue 和 react 哪个前景好

    react和vue哪个比较好 vue比较好.VUE是 iOS 和 Android 平台上的一款Vlog社区与编辑工具,允许用户通过简单的操作实现Vlog的拍摄.剪辑.细调.和发布,记录与分享生活. 还 ...

  5. Vue学习之环境构建--------vue-cli构建vue项目

    周围的朋友一直都在说vue的优点,之前一直在看angular,抱着好奇心学习了vue,想从最基础的地方记录我的vue.首先第一步离不开环境的搭建,那么就来记录我的vue环境搭建之路. 同作为前端的流行 ...

  6. vue实例没有挂载到html上,vue 源码学习 - 实例挂载

    前言 在学习vue源码之前需要先了解源码目录设计(了解各个模块的功能)丶Flow语法. src ├── compiler # 把模板解析成 ast 语法树,ast 语法树优化,代码生成等功能. ├── ...

  7. vue颜色选择器_如何制作? Vue的颜色选择器!

    vue颜色选择器 by ZAYDEK 由ZAYDEK 如何制作? Vue的颜色选择器! (How to make a ? color picker with Vue!) 注意:颜色看起来可能比实际颜色 ...

  8. vue样式 引入图片_详解Vue.js中引入图片路径的几种方式

    vue --version 3.6.3 记录总结一下的Vue中引入图片路径的几种书写方式 vue中静态资源的引入机制 Vue.js关于静态资源的官方文档 静态资源可以通过两种方式进行处理: 在 Jav ...

  9. Vue:Vue和ECharts,在Vue上进行可视化处理,在Vue上画图

    Vue:Vue和ECharts,在Vue上进行可视化处理,在Vue上画图 一.预科知识 Vue CLI ECharts 二.资源 在Vue中使用echarts 如何在 Vue 项目中使用 echart ...

最新文章

  1. SQL——将表中的最大ID+1插入新的ID中------Insert into 表 MAX(表id) +1
  2. HDOJ 2046 骨牌铺方格 【递推】
  3. 智慧交通day02-车流量检测实现07:匈牙利算法
  4. 简单解决新浪博客“您短时间发表文章过多,请稍后再试”的问题
  5. node.js 数据库操作工具类封装
  6. 图像去噪序列——BM3D图像去噪模型实现
  7. tree.js 制作酷炫照片墙
  8. heima并发30---ConcurrentHashMap--274(143-149)
  9. mp3音频转换,合并方法?-QVE音频剪辑
  10. 利用tcp三次握手,使用awl伪装MAC地址进行多线程SYN Flood
  11. ROS2学习笔记(3)什么是ROS2 topics
  12. 【毕业设计】基于云平台的火灾报警器 - stm32 物联网 单片机 OneNET云平台
  13. win server服务器 关闭危险端口 135,137,138,139,445的方法
  14. 容器化 Spring Boot 代码的 9 个技巧
  15. blockIO trace
  16. 基于STM32与ESP8266的太空人WiFi天气时钟(代码开源)
  17. 创业新手的八本武功秘籍
  18. Spring学习第6篇: 基于注解使用IOC
  19. FastASR+FFmpeg(音视频开发+语音识别)
  20. value在php中怎么使用方法,valueOf方法怎么使用

热门文章

  1. Gym 100685A Ariel (运算)
  2. Ariel India旨在宣扬共同承担家务的新影片《See Equal》引发热烈反响
  3. 独立,做新世纪的好少年,无所畏惧
  4. 【华为_WLAN】AP4030DN 由 FIT AP 更新至 FAT AP(Uboot方式)
  5. Play framework session和flash有效范围
  6. python--数据清洗
  7. 有人用这个android控制我的手机,用这个软件,竟可以随便控制别人的手机
  8. 软考各级别各科目考试分析
  9. 交易码 MWS X7 会计科目表 XXX 没有在表 T030K 中定义/交易码 VST J2 会计科目表 XXX 没有在表 T030K 中定义
  10. rpa 手机_RPA