最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Vue实践过程中的几个问题汇总

来源:动视网 责编:小采 时间:2020-11-27 20:04:34
文档

Vue实践过程中的几个问题汇总

Vue实践过程中的几个问题汇总:我们在Vue实践过程中总会遇到些问题,本文我们就针对这些问题罗列出来并向大家分享解决办法,希望能帮助到大家。本篇记录个人遇到的问题如下:路由变化页面数据不刷新问题setTimeout/setInterval this指向改变,无法用this访问VUe实例setInterva
推荐度:
导读Vue实践过程中的几个问题汇总:我们在Vue实践过程中总会遇到些问题,本文我们就针对这些问题罗列出来并向大家分享解决办法,希望能帮助到大家。本篇记录个人遇到的问题如下:路由变化页面数据不刷新问题setTimeout/setInterval this指向改变,无法用this访问VUe实例setInterva


解决方法:watch监听路由是否变化

 watch: {
 '$route' (to, from) { //监听路由是否变化
 if(this.$route.params.articleId){//是否有文章id
 //获取文章数据
 }
 }
}

setTimeout/setInterval this指向改变,无法用this访问VUe实例

场景:

 mounted(){ 
 setTimeout(function () { //setInterval同理 
 console.log(this);//此时this指向Window对象
 },1000);
 }

解决方法:使用箭头函数或者

 //箭头函数访问this实例 因为箭头函数本身没有绑定this
 setTimeout(() => { 
 console.log(this);
 }, 500);
 //使用变量访问this实例
 let self=this;
 setTimeout(function () { 
 console.log(self);//使用self变量访问this实例
 },1000);

setInterval路由跳转继续运行并没有销毁

场景:

比如一些弹幕,走马灯文字,这类需要定时调用的,路由跳转之后,因为组件已经销毁了,但是setInterval还没有销毁,还在继续后台调用,控制台会不断报错,如果运算量大的话,无法及时清除,会导致严重的页面卡顿。

解决办法:在组件生命周期beforeDestroy停止setInterval

组件销毁前执行的钩子函数,跟其他生命周期钩子函数的用法相同。

beforeDestroy(){
 //我通常是把setInterval()定时器赋值给this实例,然后就可以像下面这么暂停。
 clearInterval(this.intervalid);
},

vue 滚动行为(浏览器回退记忆位置)用法

这个我当时做的时候以为很难,后来做好了才发现就是一个设置而已(前提是要开启路由的History 模式),下面做一个简单的分享。

路由设置

  1. 要使用这一功能,首先需要开启vue-router的 history模式

如果之前一直使用的是hash 模式(默认模式),项目已经开发了一段时间,然后转history模式很可能会遇到:这些问题

  1. 滚动行为具体设置如下:

    const router = new VueRouter({
    mode: 'history',
    scrollBehavior (to, from, savedPosition) {
    //savedPosition

    if (savedPosition) { //如果savedPosition存在,滚动条会自动跳到记录的值的地方
     return savedPosition
    } else {
     return { x: 0, y: 0 }//savedPosition也是一个记录x轴和y轴位置的对象
     }
    },

    routes: [...]
    })

vue滚动行为文档,可以进到这里看看更详细的信息。

vue路由拦截浏览器后退实现草稿保存类似需求

场景:

为了防止用户突然离开,没有保存已输入的信息。

用法:

//在路由组件中:
mounted(){
},
beforeRouteLeave (to, from, next) {
 if(用户已经输入信息){
 //出现弹窗提醒保存草稿,或者自动后台为其保存
 
 }else{
 next(true);//用户离开
 }

类似的还有beforeEachbeforeRouteUpdate,也分为全局钩子和组件钩子,见路由文档。

v-once 只渲染元素和组件一次,优化更新渲染性能

觉得v-once这个api蛮6的,应该很多小伙伴都没有注意到这个api。

文档介绍:

这个api在我看来主要用于那些一次性渲染,并且不会再有操作更改这些渲染的值,这样就可以优化双向绑定的更新性能。

文档推荐:对低开销的静态组件使用 v-once

尽管在 Vue 中渲染 HTML 很快,不过当组件中包含大量静态内容时,可以考虑使用 v-once 将渲染结果缓存起来,就像这样:

Vue.component('terms-of-service', {
 template: '\
 <p v-once>\
 <h1>Terms of Service</h1>\
 ...很多静态内容...\
 </p>\
 '
})

vue风格指南推荐:

写到这里想到vue框架还有一个风格指南推荐,如下图所示,大家也可以学习一波。

相关推荐:

Vue.js2.0变化小结分享

Vue.js 2.5新特性分享

Vue.js的组件和模板详解

文档

Vue实践过程中的几个问题汇总

Vue实践过程中的几个问题汇总:我们在Vue实践过程中总会遇到些问题,本文我们就针对这些问题罗列出来并向大家分享解决办法,希望能帮助到大家。本篇记录个人遇到的问题如下:路由变化页面数据不刷新问题setTimeout/setInterval this指向改变,无法用this访问VUe实例setInterva
推荐度:
标签: 流程 VUE 里面
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top