vue.js - laravel-elixir 3:.browserify()編譯後的檔案封包找不到依賴檔: undefined
淡淡烟草味
淡淡烟草味 2017-05-16 16:50:14
0
1
670
# 相关配置版本:
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裡的Vueundefined,不知道有可能是因為什麼原因,或怎麼找出問題出在哪裡?

另外怎麼使vue這些依賴可以只需加載一次,不必一起打包在文件裡,我配置了browser-shim,但是似乎沒有起到作用,不知是使用錯了還是怎樣:

package.json
"browserify": {
    "transform": [
      "vueify",
      "browserify-shim",
      "stringify"
    ]
  },
  "browserify-shim": {
    "bootstrap-sass": {
      "depends": [
        "jquery:jQuery"
      ]
    },
    "vue": "global:Vue"
  }
淡淡烟草味
淡淡烟草味

全部回覆(1)
某草草

終於找到問題原因了(表情:泣不成聲)
index.js里的Vue可正常使用,而new.jsVue则是undefined,猜测难道它不可以多次require,但是VueRouter, VueResource也重复require了,却是可用的,思索再三,想起可能是因为package.json里写了一句把Vue設定成全域變量,於是將該句去掉,再次編譯,發現成功了(真是一知半解的副作用呀==)。去掉的那個設定如下:

"browserify-shim": {
    ...
    "vue": "global:Vue"
}

PS:感謝朋友 Vicent Ye 幫我找到問題所在了。

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板