用Vue开发一个网页并不难,但是也经常会遇到一些问题,其实大部分的问题都在文档中有所提及,再不然我们通过谷歌也能成功搜索到问题的答案,为了帮助小伙伴们提前踩坑,在遇到问题的时候,心里大概有个谱知道该如何去解决问题。这篇文章是将自己知道的一些小技巧,结合查阅资料整理成的一篇文章,如果喜欢的话可以点波赞关注,支持一下,希望大家看完本文可以有所收获。 文章内容总结:组件style的scopedVue数组对象更新视图不更新vuefilters过滤器的使用列表渲染相关深度watch与watch立即触发回调这些情况下不要使用箭头函数路由懒加载写法路由的项目启动页和404页面Vue调试神器:vuedevtools组件style的scoped: 问题:在组件中用js动态创建的dom,添加样式不生效。 场景:templatetemplatestylescoped。test{background:height:100width:100}。testAdd{background:height:100width:100}style 结果:test生效testAdd不生效。test〔datav1b971ada〕{注意datav1b971adabackground:height:100width:100} 原因: 当 它会为组件中所有的标签和class样式添加一个scoped标识,就像上面结果中的datav1b971ada。 所以原因就很清楚了:因为动态添加的dom没有scoped添加的标识,没有跟testAdd的样式匹配起来,导致样式失效。 解决方式推荐:去掉该组件的scoped 每个组件的css并不会很多,当设计到动态添加dom,并为dom添加样式的时候,就可以去掉scoped,会比下面的方法方便很多。可以动态添加style上面的栗子可以这样添加样式newDom。style。height100newDom。style。width100newDom。style。Vue数组对象更新视图不更新 很多时候,我们习惯于这样操作数组和对象:data(){data数据return{arr:〔1,2,3〕,obj:{a:1,b:2}};},数据更新数组视图不更新this。arr〔0〕OBKoro1;this。arr。length1;console。log(arr);〔OBKoro1〕;数据更新对象视图不更新this。obj。cOBKoro1;deletethis。obj。a;console。log(obj);{b:2,c:OBKoro1} 由于js的限制,Vue不能检测以上数组的变动,以及对象的添加删除,很多人会因为像上面这样操作,出现视图没有更新的问题。 解决方式:this。set(你要改变的数组对象,你要改变的位置key,你要改成什么value)this。set(this。arr,0,OBKoro1);改变数组this。set(this。obj,c,OBKoro1);改变对象 如果还是不懂的话,可以看看这个codependemo。数组原生方法触发视图更新: Vue可以监测到数组变化的,数组原生方法:splice()、push()、pop()、shift()、unshift()、sort()、reverse() 意思是使用这些方法不用我们再进行额外的操作,视图自动进行更新。 推荐使用splice方法会比较好自定义,因为slice可以在数组的任何位置进行删除添加操作,这部分可以看看我前几天写的一篇文章:【干货】js数组详细操作方法及解析合集替换数组对象 比方说:你想遍历这个数组对象,对每个元素进行处理,然后触发视图更新。文档中的栗子:filter遍历数组,返回一个新数组,用新数组替换旧数组example1。itemsexample1。items。filter(function(item){returnitem。message。match(Foo)}) 举一反三:可以先把这个数组对象保存在一个变量中,然后对这个变量进行遍历,等遍历结束后再用变量替换对象数组。 并不会重新渲染整个列表: Vue为了使得DOM元素得到最大范围的重用而实现了一些智能的、启发式的方法,所以用一个含有相同元素的数组去替换原来的数组是非常高效的操作。 如果你还是很困惑,可以看看Vue文档中关于这部分的解释。vuefilters过滤器的使用: 过滤器,通常用于后台管理系统,或者一些约定类型,过滤。Vue过滤器用法是很简单,但是很多朋友可能都没有用过,这里稍微讲解一下。 在html模板中的两种用法:!在双花括号中{{messagefilterTest}}!在vbind中 在组件script中的用法:exportdefault{data(){return{message:1}},filters:{filterTest(value){value在这里是message的值if(value1){return最后输出这个值;}}}} 用法就是上面讲的这样,可以自己在组件中试一试就知道了,很简单很好用的。 如果不想自己试,可以点这个demo里面修改代码就可以了,demo中包括过滤器串联、过滤器传参。 推荐看Vue过滤器文档,你会更了解它的。列表渲染相关 vfor循环绑定model: input在vfor中可以像如下这么进行绑定,我敢打赌很多人不知道。数据data(){return{obj:{ob:OB,koro1:Koro1},model:{ob:默认ob,koro1:默认koro1}}},html模板inputtypetextvmodelmodel〔key〕input就跟数据绑定在一起了,那两个默认数据也会在input中显示 为此,我做了个demo,你可以点进去试试。 一段取值的vfor 如果我们有一段重复的html模板要渲染,又没有数据关联,我们可以:span这里会被渲染5次,渲染模板{{n}}span vif尽量不要与vfor在同一节点使用: vfor的优先级比vif更高,如果它们处于同一节点的话,那么每一个循环都会运行一遍vif。 如果你想根据循环中的每一项的数据来判断是否渲染,那么你这样做是对的:livfortodointodosviftodo。type1{{todo}}li 如果你想要根据某些条件跳过循环,而又跟将要渲染的每一项数据没有关系的话,你可以将vif放在vfor的父节点:根据elseData是否为true来判断是否渲染,跟每个元素没有关系ulvifelseDatalivfortodointodos{{todo}}liul数组是否有数据跟每个元素没有关系ulviftodos。lengthlivfortodointodos{{todo}}liulpvelseNotodosleft! 如上,正确使用vfor与vif优先级的关系,可以为你节省大量的性能。深度watch与watch立即触发回调 watch很多人都在用,但是这watch中的这两个选项deep、immediate,或许不是很多人都知道,我猜。 选项:deep 在选项参数中指定deep:true,可以监听对象中属性的变化。 选项:immediate 在选项参数中指定immediate:true,将立即以表达式的当前值触发回调,也就是默认触发一次。watch:{obj:{handler(val,oldVal){console。log(属性发生变化触发这个回调,val,oldVal);},deep:true监听这个对象中的每一个属性变化},step:{属性watchhandler(val,oldVal){console。log(默认触发一次,val,oldVal);},immediate:true默认触发一次},}, 这两个选项可以同时使用,另外:是的,又有一个demo。 还有下面这一点需要注意。这些情况下不要使用箭头函数:不应该使用箭头函数来定义一个生命周期方法不应该使用箭头函数来定义method函数不应该使用箭头函数来定义计算属性函数不应该对data属性使用箭头函数不应该使用箭头函数来定义watcher函数 示例:上面watch的栗子:handler:(val,oldVal){可以执行console。log(默认触发一次,val,oldVal);},method:methods:{plus:(){可以执行dosomething}}生命周期:created:(){可以执行console。log(lala,this。obj)}, 是的,没错,这些都能执行。 but: 箭头函数绑定了父级作用域的上下文,this将不会按照期望指向Vue实例。 也就是说,你不能使用this来访问你组件中的data数据以及method方法了。 this将会指向undefined。路由懒加载写法:我所采用的方法,个人感觉比较简洁一些,少了一步引入赋值。constrouternewVueRouter({routes:〔path:app,component:()import(。app),引入组件〕})Vue路由文档的写法:constapp()import(。app。vue)引入组件constrouternewVueRouter({routes:〔{path:app,component:app}〕}) 文档的写法在于问题在于:如果我们的路由比较多的话,是不是要在路由上方引入赋值十几行组件? 第一种跟第二种方法相比就是把引入赋值的一步,直接写在component上面,本质上是一样的。两种方式都可以的,大家自由选择哈。路由的项目启动页和404页面 实际上这也就是一个设置而已:exportdefaultnewRouter({routes:〔{path:,项目启动页redirect:login重定向到下方声明的路由},{path:,404页面component:()import(。notFind)或者使用component也可以的},〕}) 比如你的域名为:www。baidu。com 项目启动页指的是:当你进入www。baidu。com,会自动跳转到login登录页。 404页面指的是:当进入一个没有声明没有匹配的路由页面时就会跳转到404页面。 比如进入www。baidu。comtestRouter,就会自动跳转到notFind页面。 当你没有声明一个404页面,进入www。baidu。comtestRouter,显示的页面是一片空白。Vue调试神器:vuedevtools 每次调试的时候,写一堆console是否很烦?想要更快知道组件Vuex内数据的变化? 那么这款尤大开发的调试神器:vuedevtools,你真的要了解一下了。 这波稳赚不赔,真的能提高开发效率。 安装方法:谷歌商店科学上网,搜索vuedevtools即可安装。不会科学上网?手动安装 安装之后: 在chrome开发者工具中会看一个vue的一栏,如下对我们网页应用内数据变化,组件层级等信息能够有更准确快速的了解。