# 相关配置版本:
laravel 5.1 LTS
laravel-elixir 3
vue 1.0.26
vue-router 2.0.0
vue-resources 1.0.3
使用laravel-elixir
中自帶的browserify
編譯vue, vue-router, vue-resource
成功輸出js檔案後,使用時報錯: Uncaught TypeError: Cannot read property 'use' of undefined
編譯的js檔案局部如下:
var Vue = require("vue");
var VueRouter = require('vue-router');
var VueResource = require('vue-resource');
Vue.use(VueRouter);
Vue.use(VueResource);
gulpfile.js
// 局部
elixir(function(mix) {
mix.browserify('index.js', 'public/dist/js/index.js');
mix.browserify('new.js', 'public/dist/js/new.js');
});
問題:
上面編譯的兩個文件,依賴的require
配置是一樣的,index.js這個可以使用,而new.js這個則報錯,透過console.log()
分別查看各個依賴,new.js
裡的Vue
是undefined
,不知道有可能是因為什麼原因,或怎麼找出問題出在哪裡?
另外怎麼使vue
這些依賴可以只需加載一次,不必一起打包在文件裡,我配置了browser-shim
,但是似乎沒有起到作用,不知是使用錯了還是怎樣:
package.json
"browserify": {
"transform": [
"vueify",
"browserify-shim",
"stringify"
]
},
"browserify-shim": {
"bootstrap-sass": {
"depends": [
"jquery:jQuery"
]
},
"vue": "global:Vue"
}
某草草2017-05-16 16:52:14
終於找到問題原因了(表情:泣不成聲)index.js
里的Vue
可正常使用,而new.js
的Vue
则是undefined
,猜测难道它不可以多次require
,但是VueRouter, VueResource
也重复require
了,却是可用的,思索再三,想起可能是因为package.json
里写了一句把Vue
設定成全域變量,於是將該句去掉,再次編譯,發現成功了(真是一知半解的副作用呀==)。去掉的那個設定如下:
"browserify-shim": {
...
"vue": "global:Vue"
}
PS:感謝朋友 Vicent Ye
幫我找到問題所在了。