Web前端之路Vue.js专区Web 前端开发

【Web前端】Vue项目中遇到的坑

2017-08-10  本文已影响7365人  mercurygear

开发环境

一开始只使用cnpm,一方面是墙的原因,另一方面是项目中使用了sass,不想再装ruby再build,而cnpm可以快速安装,基于这两点就愉快的使用起了cnpm;
用了一段时间还挺正常,直到项目引入了vux,使用loading组件的时候发现老是报$t未定义,上vux页面看了下,其已经提供了解决方案,说是用cnpm安装的依赖有问题,建议使用npm,这下吐血了。
最后只能搞了个曲折方案,把原来cnpm安装的vux卸载了,只是针对vux这个组件专门用npm安装,其他的还是用cnpm,居然可以工作起来,不管了,就先这样吧

微信开发者工具

用的是从官网下载的x64 0.7版本,但是一开始死活无法进行移动调试,在手机上装了个网络诊断的app,发现无法ping通同在一个局域网下的开发机,折腾了会,终于发现是win10开发机的网络发现被关闭导致,打开之后终于可以正常ping通了。
但是新问题又出现了,照着移动调试的操作说明进行,但是微信上还是无法打开网页,换用fidlle做http代理尝试,发现可以正常抓http包,且网页也能打开,怀疑是微信开发者工具的问题。
卸载微信开发者工具,重新安装,安装的时候发现x64版本的安装路径居然默认是C:\Program Files(x86),不知道这个是否有影响,先将其改成C:\Program Files,然后安装成功启动后弹出的防火墙例外把公用网络和专用网络都勾上,再次进行移动调试,这次终于可以在微信上打开网页了,泪流满面!!

Vue

  1. vue的组件式开发,一般使用单文件组件形式,且style使用scoped属性来是组件内的css设置与外界隔离,实现的手段是通过给组件内的所有元素赋予一个唯一的属性data-v-xxxxx,然后最终的生成的类选择器是带了这个属性选择的,从而实现了唯一性,但是有一点需要特别注意,就是组件的根元素,其同时是组件内部的元素,也是其父组件内部的一个子元素,所以会同时有两个data-v-xxx的属性,如果恰好该根元素上定义了一个class,其父组件的其他元素也定义了一个同名class的话,就会发生冲突,造成内部定义的class被覆盖,这点要尤为注意。
  2. 使用css的时候建议使用类选择子而不是id选择子,因为id并没有做组件隔离,所以是全局的,容易和外部冲突,同时方便后续使用BEM命名规则

Vuex + Vue-Router

  1. router的onReady回调发生在所有的vue组件创建之前(包括App.vue),所以此时router.app.$store(router.app就是根实例Vue组件)是未定义,因为$store是在组件创建的生命周期回调中注入的(beforeEach的第一个回调也是同样的情况)

微信JS-SDK

第三方库

CSS

ES6

上一篇 下一篇

猜你喜欢

热点阅读