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

开发环境

一开始只使用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命名规则
  • 为了避免组件外部对组件进行css设置同时组件的根元素也进行了css设置从而有可能发生的class名字冲突,建议在组件外部设置时用组件名字命名class,而组件内部的根元素class用组件名字作前缀并结合后缀,来避免同名class的冲突而被覆盖的情况;另外,组件的定位,大小这些建议在组件外部来决定;
  • 不要打印this.$refs.xxxx,vue会告警
  • 在移动端,虚拟键盘弹出后,window.innerHeight会变小,如果开启一个定时器去不停观察组件this.$el.getBoundingClientRect(),会发现其返回的rect还是虚拟键盘弹出之前的值,并没有动态响应更新。但是通过document.getElementById('xxxx').getBoundingClientRect()直接操作DOM来获取的rect是正确的,且对比this.$el === document.getElementById('xxx')也是true。怀疑这是vue的一个bug。
    所以,用getBoundingClientRect来判断组件是否在可视范围内的时候,要注意这点。

Vuex + Vue-Router

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

微信JS-SDK

  • 无论wx.config是否成功失败,wx.ready注册的回调总是会被调用,只是失败的时候,wx.error注册的回调也会被调用
  • iOS下如果使用audio标签,那么由于苹果不允许自动播放,需要用户手动点击才能触发播放(audio的loadstart事件都没有);但是可以借助微信sdk,在ready回调中play或者getNetworkType函数的回调中play都行
  • iOS环境,config要使用初始进入页面的url;Android则使用当前页面url(微信开发者工具虽然ua模拟ios,但是具体工作表现和android一样,这点要注意)

第三方库

  • vux:感觉上不稳定,版本之间的兼容性很糟糕,即使是rc版本,也发生过另一个同事升级到稍高的一个rc版本,结果出现运行时$route找不到的问题
  • 手淘的flexible自适应库,主要是针对iOS设备设置了dpr,并且把布局视口放大到和屏幕分辨率一样,虽然带来了像素级适配的好处,但是也给mint-ui这样的库使用带来了麻烦,会这些库中使用的字体和界面的ui变得比较小;还带来一个问题就是有可能会让大屏设置的微信二维码长按无法识别(微信二维码是截屏后识别的)

CSS

  • 背景
    一般会使用background-attachment:fixed来使得背景图片固定,但是要注意这个fixed的设置是使得背景图变成类似元素的fixed定位,依据浏览器的视口来定位的,所以理解不到位容易出现设置了这个之后图片不见了的情况

ES6

  • 默认vue的工程是不会引入babel-pollyfill的,所以尤其要注意对ES6新增的api和对象的使用,Promise这样的对象由于在移动端浏览器的支持相对完善,所以直接使用一般不会有问题;但是想Proxy这样的对象,比如在iOS 9.2下就不被原生支持,直接导致页面无法打开。解决方案也比较简单,要么不使用出问题的对象或api,要么引入babel-pollyfill(需要在入口就import,会引入一个运行时来支持)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容