前言

  一位正在学习前端的菜鸟,虽菜,但还未放弃。

内容

  1,说一下vue中的指令

  答:

    ①,v-html:主要用来渲染html节点,其作用与原生的innerHtml基本一致

    ②,v-text:主要用来渲染文本,其作用与原生的innerText基本一致

    ③,v-on:主要用来绑定事件, 简写是@ 支持多个事件一起绑定 如   v-on="{click:fun,dbclick:fun1}"

    ④,v-bind:主要用来绑定属性,简写是 : 

    ⑤,v-model:主要是用来跟表单进行双向数据绑定

    ⑥,v-for:主要用来多次渲染节点 注意:官网不推荐跟v-if一起使用,因为v-for的优先级更高 所以v-for每次在循环的时候都会进行v-if 这样很影响性能

    ⑦,v-if:主要用来判断是否创建和删除节点,可以搭配v-else 和v-else-if 一起使用

    ⑧,v-show:主要用来显示和隐藏原理,其主要原理根据css属性中的display为block和none来决定的

    ⑨,v-once:主要用来渲染元素或者组件一次的,绑定完一次后就不会再有相关联了,所以性能更好

    ⑩,v-block:主要用来解决插值表达式中的闪烁问题

  

  2,vue生命周期的的理解

    答:vue的生命周期主要分为8个阶段,3大状态(其中第一个状态一定会触发,二三阶段需要特点的条件才会触发)

      第一个状态有四个生命周期函数

        ①,创建前(beforeCreate)/创建后(created) 在beforeCreate阶段,vue实例的挂载元素el和数据对象data都为undefined,还未初始化。在created阶段,vue实例的数据对象data有了,el和数据对象data都为undefined,还未初始化。 

        ②,载入前(beforeMount)/载入后(mounted) 在beforeMount阶段,vue实例的$el和data都初始化了,但还是挂载之前为虚拟的dom节点,data.message还未替换。在mounted阶段,vue实例挂载完成,data.message成功渲染。

      第二个状态有俩个生命周期函数

        ①,更新前(beforeUpdate)/更新后(updated) 这个阶段主要是data里面的数据发生改变时,就会触发这俩个方法

      第三个状态有俩个生命周期函数

        ①,销毁前(beforeDestroy)/销毁后(destroyed) 这个阶段主要就是销毁vue实例已经解除了事件监听以及和dom的绑定才会触发,触发完以后该实例将不会再产生任何生命周期函数,但是dom依旧存在

  3,为什么vue组件里面的data必须是一个函数

    答:因为vue的组件化开发主要就是为了自己的代码自己管理,复用性高等优点,要是data里面不是作为一个函数的话,那么所有的数据对象都指向同一个data对象,当在一个组件中修改data时,其他重用的组件中的data会同时被修改,而使用返回对象的函数,由于每次返回的都是一个新对象(Object的实例),对象都是存在于堆内存里面的,他们的内存地址不一样,所以则不会出现这种问题

  4,vue中的computed和watch有什么区别?

    答:

    computed:①,支持缓存,就是只有当依赖效果发生改变时,才会重新计算,否则就是使用缓存效果,性能较好

            ②,不支持异步,当computed里面有异步的时候操作是无效的,无法监听数据的变化

          ③,如果computed写的是一个函数的话,默认是走get方法,如果需要set方法,则这俩个都要写

          ④,computed在实际开发中,更多的用于多个属性计算一个属性的时候使用

    watch:①,不支持缓存,每次data数据发生改变,都会触发该方法

       ②,支持异步,watch里面可以写异步的操作

       ③,监听的函数默认会传俩个参数过来,第一个是新的数据,第二个是之前的数据

       ④,在实际开发中,一般用在一个数据改变多个数据的时候比较推荐使用

  5,vue的双向数据绑定原理是什么?

    答:vue的双向数据绑定原理主要是结合了数据劫持和观察者模式来进行互绑的,也就是数据层改变,视图层也就跟着改变,视图层改变,数据层也就随着改变,他内部主要的原理是运用了Object.defineProperty()来劫持各个属性的setter,getter,在数据变动时发布消息给订阅者,触发相应的监听回调。

  6,vuex中有几个核心属性,分别是什么?

    答,一共有5个核心属性

      ①:state 唯一数据源,Vue 实例中的 data 遵循相同的规则

      ②:getters 可以认为是 store 的计算属性,就像computed属性一样,getter 的返回值会根据它的依赖被缓存起来,且只有当它的依赖值发生了改变才会被重新计算。getter 会暴露为 store.getters 对象,你可以以属性的形式访问这些值

      ③:mutation 更改 Vuex 的 store 中的状态的唯一方法是提交 mutation,非常类似于事件,通过store.commit 方法触发

      ④:action action 类似于 mutation,不同在于Action 提交的是 mutation,而不是直接变更状态,Action 可以包含任意异步操作

      ⑤:module  由于使用单一状态树,应用的所有状态会集中到一个比较大的对象。当应用变得非常复杂时,store 对象就有可能变得相当臃肿。为了解决以上问题,Vuex 允许我们将 store 分割成模块

vue中一些常见的面试题的更多相关文章

  1. vue中一些常见错误

    一:在抽取路由模块时路径没有更改过来 二:跨域的问题

  2. vue中数据双向绑定的实现原理

    vue中最常见的属v-model这个数据双向绑定了,很好奇它是如何实现的呢?尝试着用原生的JS去实现一下. 首先大致学习了解下Object.defineProperty()这个东东吧! * Objec ...

  3. vue中关于prop

    组件之间的项目通信在vue中十分常见,父组件的数据传到子组件需要prop的支持,我们来看下prop 1.html的特性名大小写不敏感,浏览器会把所有大写字母解释为小写字母,使用dom模板时,使用等价的 ...

  4. Vue基础01vue的基本示例,vue的双向数据绑定,vue中常见的几种用法,vue相关常见指令

    自学vue框架,每天记录重要的知识点,与大家分享!有不足之处,希望大家指正. 本篇将讲述:vue的基本示例,vue的双向数据绑定,vue中常见的几种用法,vue相关常见指令 前期学习基础,使用vue. ...

  5. Java 基础常见知识点&面试题总结(中),2022 最新版!| JavaGuide

    你好,我是 Guide.秋招即将到来,我对 JavaGuide 的内容进行了重构完善,公众号同步一下最新更新,希望能够帮助你. 上篇:Java 基础常见知识点&面试题总结(上),2022 最新 ...

  6. vue中常见的指令

    1,差值表达式{{}} <p >{{ msg }}</p> 2.v-cloak解决差值表达式闪烁的问题 <p v-cloak>{{ msg }}</p> ...

  7. vue 中一些API 或属性的常见用法

    prop 官方解释:Prop 是你可以在组件上注册的一些自定义特性.当一个值传递给一个 prop 特性的时候,它就变成了那个组件实例的一个属性. 通俗点讲就是:prop是父组件用来传递数据的一个自定义 ...

  8. Vue中常见参数传递方式

    文章内容:这里只有vue中父子组件传参.路由间的传参 (另外还有vuex.储存本地.中央bus等方式) 一.父子组件 1.1父传子(props) <!-- 父组件father.vue --> ...

  9. vue中,怎么给data对象添加新的属性?(尼玛这面试题居然让我给碰上了。。。。)

    Vue中给data中的对象属性添加一个新的属性时会发生什么,如何解决? 示例: <template> <div> <ul> <li v-for="v ...

随机推荐

  1. 5 个 IDEA 必备插件,让效率成为习惯

    IDEA 是最好的 IDE,谁赞成,谁反对? IDEA 是 Java 开发人员中最受欢迎和用户友好的 IDE 之一,它具有许多便利的功能,例如智能代码完成,自动执行繁琐的重复开发任务,因此它已成为 J ...

  2. Oracle基础介绍及常用相关sql*plus命令

    以管理员身份运行Database Configuration Assistant,新建数据库实例. 要使用Oracle首先要启动Oracle服务,在任务管理器中找到服务,打开有关OracleServi ...

  3. php基础学习中认为重点的知识

    <?php ... ?> 简写成 <? ... ?> 服务器中可以通过php.ini中配置short_open_tag为on来实现 php语句必须以分号  ; 结尾 .  连接 ...

  4. JavaWeb项目的目录结构解释(上):

    当我们在IDEA创建JavaWeb项目时,默认的一般会有下图的目录结构,你的开发就是按照下列结构进行开发的,那么我就逐一解释他们的意思: 首先是demo:这个是项目的名字,一般你是自己创建一个与自己项 ...

  5. Ethical Hacking - Web Penetration Testing(1)

    How to hack a website? An application installed on a computer. ->web application pen-testing A co ...

  6. JAVA集合三:几种Set框架

    参考链接: HOW2J.CN HashSet简单讲解 HashSet HashSet与C++STL中Set基本类似,具有的特点便是: 集合中元素不可重复 集合中元素顺序 ≠ 插入顺序 常用方法 功能 ...

  7. 015.Nginx重定向

    一 重定向概述 1.1 重定向介绍 重定向(Redirect)指通过各种方法将各种网络请求重新定个方向转到其它位置(如:网页重定向.域名的重定向.路由选择的变化也是对数据报文经由路径的一种重定向). ...

  8. 将一个Linux系统中的文件或文件夹复制到另一台Linux服务器上(scp的使用)

    一.复制文件: (1)将本地文件拷贝到远程scp 文件名 用户名@计算机IP或者计算机名称:远程路径(2)从远程将文件拷回本地scp 用户名@计算机IP或者计算机名称:文件名 本地路径 二.复制文件夹 ...

  9. 面试题千变万化,为什么总是会问MySQL?

    前言 当你简历上写了 熟悉mysql关系型数据库时,那肯定免不了面试官对于myql索引.事务,慢查询等等的考察 那么到底什么是索引,索引的数据类型有哪些,它们的优缺点以及如何去排查那些慢SQL语句等, ...

  10. Docker 入门教程(3)——Dockerfile

    Dockerfile Dockerfile是一个文本文件,用来定制镜像. 镜像是分层存储的,前一层会是下一层的基础.而镜像的定制就是定制每一层镜像在上一层做了什么改变. Dockerfile其内包含一 ...