vue 生命周期,vuex,路由,导航守卫,methods,computed和watch区别,v-if和v-show区别,v-for和v-if,总结。

一.生命周期

1.什么是生命周期函数

生命周期函数 又叫钩子函数 是到了某一个时间点会自动触发 我们讨论的是 vue 实例的钩子函数 从 vue 实例创建到销毁的过程中 到了一定的时间节点就会触发

1.1 生命周期函数有哪些

创建阶段

  • beforeCreate 实例创建之前 这个时候什么都没有 data methods 都不能用 也没有 this

  • created 创建之后 也是最早的可以使用 data 和 methods 的钩子函数 这个时候有 this 了

  • beforeMount 组件挂载之前

  • mounted 组件挂载之后 这个时候能拿到 dom 节点使用

运行阶段 只要修改 data 就会触发

  • beforeUpdate 数据变了 视图还没变

  • updated 数据变了 视图也变了

销毁阶段

  • beforeDestory 组件销毁之前 是最后一个能使用 data 和 methods 的钩子函数

  • destoryed 组件销毁之后

除了这八个 还有 三个 如果用 keep-alive 缓存了组件 就会有 actived deactived 这两个钩子函数 activated 组件激活 deactivated 组件停用 errorCaptured 子组件出错的时候会触发这个钩子函数

1.2 项目开发中 在生命周期里都做过什么功能

我在写效果的过程中 会在 created 或者 mounted 中发送 http 请求

created 和 mounted 的区别 就是 created 比 mounted 执行的时间更早所以会更多的在 created 中请求 mounted 的特点是可以操作 dom 节点

还会用 created 钩子函数 获取 本地存储的数据

1.3 ⻚⾯第⼀次加载时⽗⼦组件⽣命周期执⾏的顺序是什么?

自己试一试 把顺序写一下

页面—beforeCreate

页面—created

页面—beforeMount

组件—beforeCreate

组件—created

组件—beforeMount

组件—mounted

页面—mounted

2.vuex 的理解

vuex 是 vue 的状态管理工具 管理项目中的公共数据 能够在所有的组件中使用 一共有五大核心 state 存放公共数据的地方 通过 this.$store.state.xxx调用 mutations 修改 state 的地方 只有这里能修改 通过this.$store.commit 调用 getters 相当于是之前的计算属性 通过 this.$store.getters 调用 actions 执行异步操作的地方 通过 this.$store.dispatch 调用 modules 模块化

vuex 缺点就是刷新数据会丢失 我们可以保存本地存储 或者 安装 vuex 持久化插件 vuex-persist 去实现自动本地存储

2.1vuex 的执行机制

我在项⽬当中如果要改变 state 的状态,我们⼀般是在组件⾥⾯调⽤ this.$store.dispatch ⽅式来触发 actions ⾥⾯的⽅法,在 actions ⾥⾯的⽅法通过 commit 来调⽤ mutations ⾥⾯定义的⽅法来改变 state,同时这也是 vuex 的执⾏机制

2.2 怎么开启严格模式

strict: true, 跟 state 同级的地方设置这个属性 开启完严格模式后 如果不是通过 mutation 修改的 state 就会报错 strict 严格模式只适合开启在开发环境下

2.3 modules

把仓库里的数据分模块管理

每个模块里又有四个核心 state mutations getters actions

然后引入仓库 并且在 modules 下注册模块 在定义的 modules 里开启一个命名 namespaced:true

export default {
  computed: {
    arr() {
      return this.$store.state.a.arr;
      //使用 模块a里的state数据arr
    },
  },
  methods: {
    add() {
      this.$store.commit("a/add");
      //调用a下面的add方法
    },
  },
};

三.路由的模式 以及原理 区别

⾯试官您好,接下来我给您介绍⼀下 vue 的路由模式,vue 的路由模式⼀共有两种,分别是哈希和 history.他们的区别是 hash 模式不会包含在 http 请求当中,并且 hash 不会重新加载⻚⾯,⽽使⽤ history 模式的话,如果前端的 url 和后端发起请求的 url 不⼀致的话,会报 404 错误,所以使⽤ history 模块的话我们需要和后端进⾏配合. history 的原理就是利⽤ ht

四.导航守卫

路由的导航守卫 又叫做路由的钩子函数(生命周期函数) 就是在跳转页面的 时候把 路由拦下来 做一些操作 再放行 一共有三种

第一种是全局守卫 beforeEach 路由进入之前 afterEach 路由进入之后

第二种 组件内守卫 beforeRouteEnter 路由进入之前 beforeRouteUpdate 路由更新之前 beforeRouteLeave 路由离开之前

第三种 独享守卫 beforeEnter 路由进入之前

有三个参数 to from next next 这个参数 在路由 3.x 版本的时候 是必须的 但是到了路由 4.x 版本的时候 next 参数变成可选的了

一般来说 vue2 搭配 3.x 的路由 vue3 搭配 4.x 的路由

比如说 购物车页面只有登陆的才能访问 我们可以用组件级守卫守卫购物车页面 如果已经登陆存的有 token 的话 就继续访问这个页面 如果没有登陆的话就会跳转到登陆页面

  beforeRouteEnter(to, from, next) {
    if (localStorage.getItem("token")) {
      next();
    } else {
      next("/login");
    }

next 参数 除了括号里可以是空和路径之外 还可以是一个回调函数(回调函数就是一个被作为参数传递的函数) 比如说 token 被存进 vuex 里就能这么写:

  beforeRouteEnter(to, from, next) {
    // if (localStorage.getItem("token")) {
    //   next();
    // } else {
    //   next("/login");
    // }
    next((vm) => {
      // vm就是 这个组件实例 就是this
      if (vm.$store.state.token) {
        next();
      } else {
        next("/login");
      }
    });
  },

五.methods computed watch

5.1 methods 就是方法 我们写的点击事件等各种事件都放在 methods 里

5.2 计算属性 computed 计算属性 有缓存功能就是当跟他有关的值发生变化的时候才会重新计算 还有一个特点就是必须要有 return 值 return 就是把计算的结果 return 出去

5.3 watch watch 可以监听 数据和路由的变化

watch 监听路由的变化 监听路由的话就是监听 $router

  watch: {
    $route: {
      handler(newval, oldval) {
        console.log(newval, oldval);
      },
    },
  },

watch 监听 数据的变化 watch 有三个参数 deep immediate handler 当我们不需要 deep 和 immediate 的时候 就可以简写为一个函数 这个函数就是 handler

 watch: {
    num: {
      deep: true, //深度监听
      immediate: true, //进入页面立刻监听
      handler(newval) {
        console.log(newval);
      },
      //执行函数 参数是newval 和 oldval
    },
​
    // num() {},
    // 之前写的只有一个函数的情况 是handler的简写 不需要 deep 和 immediate的时候可以简写
  },

六.v-ifv-show的区别?

⾯试官您好 , 接下来我给您介绍⼀下 v-if v-show 的区别 ? ⾸先 v-if v-show 都是控制元素的显示与隐藏 , 不过 v-if 控制元素的显 示和隐藏的时候会删除对⽤的dom 元素 , 当每⼀个显示的时候 , 都会重新创建 dom 和渲染 . v-show 则是通过 css display:none 和display:block 来控制元素的显示与隐藏 . v-if ⽐较耗费性能 , 所以我们涉及到频繁的显示隐藏操作我们建议使⽤ v-show, 如果不 是频繁操作的话, 我们可以 v-if。
在项⽬中我会经常使⽤ v-if v-show, ⽐如我们在搜索功能的时候 , 他有⼀个历史记录 , 这个时候我们根据是否有搜索的结果来判 断历史记录的显示与隐藏, 这块我就可以使⽤ v-if , 当然⽤ v-show 也可以 . 以上就是我对 v-if v-show 的理解 .

七.v-forv-if的优先级那个⾼?如果同时使⽤v-forv-if怎么解决?

v-for 的优先级⾼ . 因为 v-for 的时候我们才开始渲染 dom 元素 , 这个 v-if 还⽆法进⾏判断。
v-for v-if 不能同时使⽤ , 我们可以通过标签 , ⽐如 div 或者 template 标签来进⾏包裹 , v-if 写到包裹的标签上⾯ ( 写到 v-for 外⾯ )。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
1. 双向数据绑定的原理 简述一下MVVM。 MVVM是Model-View-ViewModel的缩写,是一种前端架构模式。它通过数据绑定实现了View和Model的自动同步,ViewModel作为View和Model之间的桥梁,负责处理View的事件和数据绑定,同时也负责将Model的数据转换为View所需的数据格式。MVVM的核心思想是数据驱动,通过数据的变化来驱动视图的变化。 2. 知道MVC吗?说一下区别 MVC是Model-View-Controller的缩写,也是一种前端架构模式。与MVVM不同的是,MVC中的Controller负责处理View的事件和数据绑定,同时也负责将Model的数据转换为View所需的数据格式。而在MVVM中,ViewModel承担了Controller的职责,负责处理View的事件和数据绑定。 3. Vue实现数据响应式的基本原理 Vue实现数据响应式的基本原理是通过Object.defineProperty()方法对数据进行劫持,当数据发生变化时,会触发对应的更新操作,从而实现视图的自动更新。 4. 使用 Object.defineProperty() 来进行数据劫持有什么缺点? 使用Object.defineProperty()进行数据劫持的缺点是无法监听到数组的变化,需要通过特殊的方法来实现数组的监听。 5. ComputedWatch区别 Computed是计算属性,它会根据依赖的数据动态计算出一个新的值,并缓存起来,只有当依赖的数据发生变化时才会重新计算。而Watch是监听器,它会监听指定的数据变化,并在数据变化时执行指定的回调函数。 6. ComputedMethods区别 ComputedMethods区别在于,Computed是计算属性,它会根据依赖的数据动态计算出一个新的值,并缓存起来,只有当依赖的数据发生变化时才会重新计算;而Methods是方法,它会在每次调用时重新计算。 7. slot是什么?有什么作用?原理是什么? slot是Vue中的插槽,它允许我们在组件中插入任意内容,从而实现组件的复用和灵活性。原理是在组件中定义一个或多个slot,然后在使用组件时,将需要插入的内容放在对应的slot中即可。 8. 过滤器的作用,如何实现一个过滤器 过滤器的作用是对数据进行格式化或处理,从而满足特定的需求。实现一个过滤器需要在Vue实例中定义一个filters对象,然后在模板中使用管道符“|”将需要过滤的数据和过滤器名称连接起来,例如:{{ data | filterName }}。 9. 如何保存页面的当前的状态 可以使用Vue Router的导航守卫来保存页面的当前状态,例如在beforeRouteLeave钩子函数中将当前页面的状态保存到localStorage中,在beforeRouteEnter钩子函数中从localStorage中读取保存的状态并恢复页面。 10. 常见的事件修饰符及其作用 常见的事件修饰符有:.stop、.prevent、.capture、.self、.once,它们的作用分别是阻止事件冒泡、阻止默认事件、使用事件捕获模式、只在事件目标自身触发时触发事件、只触发一次事件。 11. v-if、v-show、v-html 的原理 v-if和v-show都是Vue中的条件渲染指令,v-if会根据条件动态添加或删除DOM元素,而v-show则是通过CSS样式来控制元素的显示和隐藏。v-html指令用于将数据作为HTML插入到模板中。 12. v-if和v-show的区别 v-if和v-show的区别在于,v-if会根据条件动态添加或删除DOM元素,而v-show则是通过CSS样式来控制元素的显示和隐藏。当条件不满足时,v-if会将对应的DOM元素从DOM树中删除,而v-show只是将元素的display属性设置为none。 13. v-model 是如何实现双向数据绑定的? v-model是通过对input事件和value属性的绑定来实现双向数据绑定的。当用户输入数据时,会触发input事件,从而更新数据模型中的值;当数据模型中的值发生变化时,会将新的值赋给input元素的value属性,从而更新视图。 14. data为什么是一个函数而不是对象 data为函数而不是对象的原因是为了实现数据的复用。当组件被复用时,如果data是一个对象,那么所有的组件实例都会共享同一个数据对象,从而导致数据混乱;而如果data是一个函数,每个组件实例都会调用一次该函数,从而实现数据的独立性。 15. 对keep-alive的理解,它是如何实现的,具体缓存的是什么? keep-alive是Vue中的一个抽象组件,它可以将动态组件缓存起来,从而提高组件的性能。keep-alive的实现原理是通过在组件的生命周期中添加beforeRouteLeave和activated钩子函数来实现缓存和恢复。具体缓存的是组件的状态和DOM结构。 16. Vue 单页应用与多页应用的区别 Vue单页应用是指所有的页面都在一个HTML文件中,通过Vue Router实现页面的切换和路由控制;而Vue多页应用是指每个页面都有自己的HTML文件,通过Vue实现组件化和数据驱动。 17. Vue template 到 render 的过程 Vue template到render的过程是通过Vue的编译器将template模板编译成render函数,然后将render函数渲染成真实的DOM元素。在编译过程中,Vue会将模板中的指令和表达式转换为对应的render函数代码,从而实现模板到render的转换。 18. Vue data 中某一个属性的值发生改变后,视图会立即同步执行重新渲染 吗? 不一定,Vue使用异步更新队列来处理数据的变化和视图的更新,当数据发生变化时,Vue会将更新操作推入到异步更新队列中,然后在下一个事件循环中执行更新操作,从而实现性能的优化。 19. 描述下Vue常用指令 Vue常用指令有:v-if、v-show、v-for、v-bind、v-on、v-model、v-html、v-text等。它们分别用于条件渲染、显示和隐藏元素、循环渲染、绑定属性、绑定事件、实现双向数据绑定、插入HTML和插入文本等操作。 20. 描述下Vue自定义指令 Vue自定义指令是一种扩展Vue功能的方式,它可以用于封装常用的DOM操作和行为,从而提高代码的复用性和可维护性。自定义指令需要在Vue实例中定义一个directives对象,然后在模板中使用v-指令名称来调用自定义指令。 21. 子组件可以直接改变父组件的数据吗? 不可以,子组件不能直接改变父组件的数据,因为Vue中的数据流是单向的,只能从父组件向子组件传递数据。如果需要改变父组件的数据,可以通过在子组件中触发事件并传递数据的方式来实现。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

灏哥哥灬

你的鼓励将是我创作的最大动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值