• 【面试题-Vue】常见问题一、指令类


    一、常用到的指令有哪些?

    v-html、v-text、v-show、v-if、v-else、v-else-if、v-for、v-bind、v-on、v-model等等。

    不常用的指令
    v-pre 令vue语法失效
    v-once 元素只渲染一次

    二、v- show 与 v - if 有什么区别?

    v - if:真正意义上的条件渲染,对dom树发生改变。为true是渲染(dom存在),为false时不存在(dom不存在)。
    v-show是通过控制display属性来进行dom的显示与隐藏

    性能区别:
    1、v-if有更高的切换开销,v-show有更高的初始渲染开销。
    如果需要频繁的切换,使用v-show比较好,如果运行条件很少改变,使用v-if比较好。
    2、v-show比v-if性能更高,因为v-show只能动态的改变样式,不需要增删DOM元素。所以当程序不是很大时候,v-if和v-show区别都不大,如果项目很大,推荐多用v-show,较少浏览器后期操作的性能。
    3、需要多种条件场景,比如id=1,=2,=3…时候,因为只有v-if,可以和v-else等连用,这种比较适合用v-if。
    4、v-show不支持语法。
    5、v-if切换时候回实时的销毁和重建内部的事件、钩子函数等,v-show只会初始化渲染时候执行,再切换时候不会执行生命后期的过程

    三、v- for 中 key 是否为必须?以及它的作用?

    必须的。
    使用v-for循环一个list,当list发生更新时,v-for默认使用 就地更新策略进行渲染,即根据 key 值去判断某个数据是否修改,如果修改了就重新渲染,不然就复用之前的元素。
    方案一:使用index作为key,不推荐
    1.在list最后添加一条数据,此时用 index 作为 key,没有任何问题,
    2.在list中间插入一条数据,此时用 index 作为 key,很多条数据的index会发生改变,因此v-for会渲染多条数据,降低效率,因此不推荐的。
    方案二:使用id(list数据中具有唯一性的值)作为key,推荐
    多数情况只会渲染一条数据,相比之下效率更高一些。

    四、谈一下v-for和v-if的优先级

    在源码中,v-for优先与v-if被解析,也就是说v-for优先级更高

    常遇到的问题:
    同时使用两者是,每次v-for循环,都会执行一次v-if,假设有个容量为1000的数组,那么v-if会被执行1000次,会十分消耗性能,降低代码质量。

    怎么处理这种问题?这要根据判断调试是否和循环的内容有关系,分为两种情况:
    1.在v-if不依赖v-for中某个值的前提下:可以在循环的外层添加template标签,在template中做v-if判断,这样可以让v-if的判断优先。

       <template v-if="isShowList">
          <div v-for="(item)in list" :key="item.id">
            <span>{{item.name}}</span>
          </div>
        </template>
        ...
          isShowList:true,
          list: [
            { id: 0, name: '张三' },
            { id: 1, name: '李四' },
            { id: 2, name: '王五' }
          ]
          ...
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    2.当v-if的判断条件依赖于v-for的内容时:可以在computed计算属性里先做好判断,过滤出符合条件的元素重新组成新的数组,在dom中循环这个新的数组。这样就不需要加v-if判断了。要知道,在computed里过滤的成本远比v-if低的多。

        <div v-for="(item) in newlist" :key="item.id">
          <span>{{item.name}}</span>
        </div>
        ...
         list: [
            { id: 0, name: '张三', isShow: true },
            { id: 1, name: '李四', isShow: false },
            { id: 2, name: '王五', isShow: true }
          ]
        ...
        computed: {
        	newlist() {
         	 return this.list.filter(v => v.isShow)
        	}
      },
        ...
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
  • 相关阅读:
    Docker的数据管理(数据卷,容器互联)
    简单几个步骤,轻松完成短视频配音工作|别惊讶,让我手把手教你
    ansible安装和常见模块
    30天刷题计划(五)
    Linux篇 五、Ubuntu与Linux板卡建立NFS服务
    字符串压缩
    无锡设计培训:PLC控制的基本原则
    Elasticsearch优化
    KMP算法——通俗易懂讲好KMP算法:实例图解分析+详细代码注解 --》你的所有疑惑在本文都能得到解答
    JavaScript中的箭头函数
  • 原文地址:https://blog.csdn.net/ZMN0057/article/details/127896152