vue 常见面试题(使用)

0. 指令、插值

  • 插值、表达式
  • 指令、动态属性
  • v-html:会有XSS风险,会覆盖子组件


    image.png

    image.png

00. computed 和 watch

image.png

image.png

image.png

000. class 和 style

image.png

image.png

image.png

1. v-show 和 v-if 的区别?

区别:
v-show 的显示与隐藏,只是在设置为 display: none
v-if 的显示与隐藏,会创建和销毁 DOM 节点
应用场景:
如果只有一次的显示或隐藏,用 v-if;
如果有多次显示或隐藏的切换,用 v-show


image.png

2. 为何 v-for 中要用 key?

3. 描述 Vue 组件生命周期 (有父子组件的情况)

生命周期(单个组件)

  • 挂载阶段
    created 与 mounted 的区别?
    created 页面还没有渲染,但是 Vue 实例已经初始化完了
    mounted 页面已经渲染完了
  • 更新阶段
  • 销毁阶段
    lifecycle.png

    生命周期(父子组件)
    image.png
image.png
image.png

4. Vue 组件如何通讯?

  • 父组件 向 子组件传递参数,props
  • 子组件 向 父组件触发一个事件,this.$emit
  • 兄弟组件之间的通信,自定义事件
// event.js
import Vue from 'vue';
export default new Vue();
// list.vue
import event from './event'
// 调用自定义事件
event.$emit('onAddTitle', this.title)
// 绑定自定义事件
event.$on('onAddTitle', this.addTitleHandler)
// 解绑自定义事件(避免造成内存泄露)
event.$off('onAddTitle', this.addTitleHandler)

【注】beforeDestroy 可能可以执行哪些事情:可以解绑自定义事件,还有就是注意,子组件调用父组件事件,用 this.$emit;而调用自定义事件,用 event.$emit

5. 描述组件渲染和更新的过程?

6. 双向数据绑定 v-model 的实现原理?

7. v-for 与 v-if 不能一起用?

v-for 比 v-if 计算优先级高一些,会影响性能。

8. event 参数?

  • even 是原生的
  • 事件被挂载到当前元素

9. 事件、按键修饰符有哪些?

image.png

image.png

10. 表单

https://zhuanlan.zhihu.com/p/107502613

<input type="text" v-model.trim="name"/> //截取前后的空格
<input type="text" v-model.lazy="name"/> //输入过程中不会变化
<input type="text" v-model.number="name"/> //转换为数字

<input type="checkbox" v-model="check" /> //复选框也是用v-model check是布尔值

<input type="checkbox" id="jack" value="Jack" v-model="checkbox" />
<label for="jack">Jack</label> // checkbox 是数组 [],多选框
<input type="checkbox" id="john" value="john" v-model="checkbox" />
<label for="john">john</label>

<input type="radio" id="male" value="male" v-model="gender" />
<label for="jack">男</label> // checkbox 是值,单选框
<input type="radio" id="female" value="female" v-model="gender" />
<label for="john">女</label>

<textarea v-model="desc"></textarea>
<! 注意,<textarea>{{desc}}</textarea> 是不允许的!>

// 下拉列表选择(单?。﹕elected 是值
<select v-model="selected">
    <option disabled value="">请选择</option>
    <option disabled>A</option>
    <option disabled>B</option>
    <option disabled>C</option>
</select>

// 下拉列表选择(多?。﹕electedList 是数组 []
<select v-model="selectedList" multiple>
    <option disabled value="">请选择</option>
    <option disabled>A</option>
    <option disabled>B</option>
    <option disabled>C</option>
</select>

11. Vue 的高级特性

  • 自定义 v-model(颜色选择器)

index.vue

image.png

image.png

CustomVModel.vue

image.png

image.png
  • $nextTick
    为什么要用 nextTick?

    image.png

    image.png

  • refs
    获取DOM元素的方式


    image.png

    image.png
  • slot


    image.png

基本使用

image.png

image.png

SlotDemo

image.png

作用域插槽

image.png

image.png

ScopeSlotDemo

image.png

具名插槽

image.png

image.png

  • 动态、异步组件
    动态组件
    image.png
image.png

image.png

异步加载组件(性能优化)

image.png

image.png

  • keep-alive(缓存组件)


    image.png

    image.png
  • mixin
    image.png

    index.vue
    image.png

    MixinDemo
    image.png

    image.png

    mixin.js
    image.png

存在问题

image.png

12. v-show 与 keep-alive 的区别?

v-show:通过原生CSS(display:none)进行控制(渲染);在比较简单的情况下,即标签不是很多的情况下,可用 v-show进行控制(渲染)
keep-alive:在Vue层级(框架层级)进行渲染;组件较多的情况下,如 tab 切换等情况下,用 keep-alive 比较合适
一个组件,即一个 js 对象

13. vuex 使用

image.png

基本概念

image.png

用于 vue 组件

image.png

image.png

Actions 里面才能做异步操作

应用场景

  • 多个视图依赖于同一状态(例如:菜单导航)
  • 来自不同视图的行为需要变更同一状态(例如:评论弹幕)

13. Vue-router 使用

image.png
image.png

H5 history 路由模式配置

image.png

Vue-router 路由配置 动态路由

image.png

Vue-router 路由配置 懒加载

image.png

注意

image.png

14. 路由跳转有几种方式?

  • router-link
<router-link to="keyframes">点击验证动画效果 </router-link>
  • this.$router.push()
    描述:跳转到不同的url,但这个方法会向history栈添加一个记录,点击后退会返回到上一个页面。
  • this.$router.replace()
    描述:同样是跳转到指定的url,但是这个方法不会向history里面添加新的记录,点击返回,会跳转到上上一个页面。上一个记录是不存在的。
  • this.$router.go(n)
    相对于当前页面向前或向后跳转多少个页面,类似 window.history.go(n)。n可为正数可为负数。正数返回上一个页面
最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,128评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,316评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,737评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,283评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,384评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,458评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,467评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,251评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,688评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,980评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,155评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,818评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,492评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,142评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,382评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,020评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,044评论 2 352

推荐阅读更多精彩内容