使用vue遇到的一些问题

当前项目需要用vue重写,由于Vue还是初学,所以肯定会遇到一些问题,在这里记录一下,方便查看。

vuex绑定到v-model提示

[Vue warn]: Computed property "productSeries" was assigned to but it has no setter.

描述: 将vuex中的数据直接拿出来并通过v-model绑定到页面元素上,报错。原因是vuex类似redux,其数据只允许通过vuex提供的方法,action、mutation来更改。

解决: 思考这个数据节点是不是特别有必要放在vuex,如果不需要,则只绑定到当前组件就行了,如果需要,则有两种方法解决:1、在当前组件的data中定义一个对象来接收store中的数据;2、加入get和set方法。

P.S. vuex给我的感觉:数据能写在当前页面就写在当前页面,尽量少用vuex。不然又要写get/set方法,又要考虑action/dispatch,感觉有点麻烦,不能突出vue双向绑定的优势。

Vue-cli生成的项目在局域网调试的问题

描述: 在mac上面用vue-cli创建的项目,直接npm start打开调试,本机可以用localhost:8080打开,mac在局域网内的地址为 192.168.43.102,然而我用一台windows输入 192.168.43.102:8080 却打不开,感觉可能是vue-cli没有默认配置。

解决: 打开项目根目录下的config/index.js,看到host这一行

host: 'localhost', // can be overwritten by process.env.HOST

恩,可以直接在node进程写HOST
遂打开根目录下的package.json,修改start命令,添加一个HOST

"start": "npm run dev"

改成

"start": "HOST=0.0.0.0 npm run dev"

执行npm start

问题解决

Vuex在IE11无法使用的问题

描述: 客户需要兼容IE11,直接用IE11打开页面,发现页面空白,什么都没显示。
打开IE的控制台,出现了vuex的提示:
[vuex] vuex requires a Promise polyfill in this browser
看来是IE11不支持Promise

解决: 上github,搜到两个相关的问题

https://github.com/vuejs-templates/webpack/issues/260
https://github.com/vuejs-templates/webpack/issues/474

尤大提示 解决方案就是引入babel-polyfill或者es6-promise
看了一下其他回复,我选择安装es6-promise

npm install es6-promise

然后在main.js第一行引入

// 添加es6-promise以兼容IE
import 'es6-promise/auto';

import Vue from 'vue';
import App from './App';
import router from './router';
import store from './store';
// 其他内容

问题解决

Cannot read property 'compilation' of undefined的问题

描述: 用vue-cli生成的一个项目,直接npm run build,报错

> tms-vue-ele@1.0.0 build /Users/jianghai/codes/tms-vue-ele
> node build/build.js
⠋ building for production.../Users/jianghai/codes/tms-vue-ele/node_modules/last-call-webpack-plugin/src/index.js:170
 compiler.hooks.compilation.tap(
 ^
TypeError: Cannot read property 'compilation' of undefined
 at OptimizeCssAssetsWebpackPlugin.apply (/Users/jianghai/codes/tms-vue-ele/node_modules/last-call-webpack-plugin/src/index.js:170:20)
 at Compiler.apply (/Users/jianghai/codes/tms-vue-ele/node_modules/tapable/lib/Tapable.js:375:16)
 at webpack (/Users/jianghai/codes/tms-vue-ele/node_modules/webpack/lib/webpack.js:33:19)
 at err (/Users/jianghai/codes/tms-vue-ele/build/build.js:19:3)
 at next (/Users/jianghai/codes/tms-vue-ele/node_modules/rimraf/rimraf.js:75:7)
 at CB (/Users/jianghai/codes/tms-vue-ele/node_modules/rimraf/rimraf.js:111:9)
 at /Users/jianghai/codes/tms-vue-ele/node_modules/rimraf/rimraf.js:137:14
 at FSReqWrap.oncomplete (fs.js:152:21)

解决: 根据提示,打算一层一层找,首先第一行

at OptimizeCssAssetsWebpackPlugin.apply (/Users/jianghai/codes/tms-vue-ele/node_modules/last-call-webpack-plugin/src/index.js:170:20)

可能是OptimizeCssAssetsWebpackPlugin这个方法的问题,首先上npm找到optimize-css-assets-webpack-plugin这个包

https://www.npmjs.com/package/optimize-css-assets-webpack-plugin

官方提示:
For webpack v3 or below please use optimize-css-assets-webpack-plugin@3.2.0. The optimize-css-assets-webpack-plugin@4.0.0 version and above supports webpack v4.

遂打开package.json,发现webpack版本3.6.0,optimize-css-assets-webpack-plugin版本5.0.1
判断是这个原因,卸载之,重装到3.2.0

npm uninstall optimize-css-assets-webpack-plugin --save-dev
npm i optimize-css-assets-webpack-plugin@3.2.0 --save-dev

然后执行npm run build,成功!

问题解决

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

推荐阅读更多精彩内容

  • ## 框架和库的区别?> 框架(framework):一套完整的软件设计架构和**解决方案**。> > 库(lib...
    Rui_bdad阅读 2,902评论 1 4
  • 本文主要从一个上线项目的packge.json分析一个上线项目中常见的插件以及为什么会引入这些插件。 通过这些配置...
    Leslie_2386阅读 996评论 0 2
  • 本文主要从一个上线项目的packge.json分析一个上线项目中常见的插件以及为什么会引入这些插件。 通过这些配置...
    程序员之路阅读 502评论 0 2
  • 简介 vue cli 3 是一个类似于 create-react-app 的可以用例命令行快速配置和生成一个 vu...
    VioletJack阅读 9,471评论 3 22
  • 爸: 爸,有很多感激、感恩、贴心的话想和你说,却当着你的面说不出口,我们都是不善表达感情的人。可我却很想让您知道我...
    墙角寒梅阅读 100评论 0 0