Skip to content

[webpack、angular] 打包 angular Uncaught Error: [$injector:modulerr]

Published: at 09:12 AM (2 min read)

剛開始學 webpack 打包 javascript、CSS 及一些圖片資源等

使用 angular 時總是遇到下完 webpack -p (壓縮打包的資源)

產生出來的 js 檔發生 inject error,其實明顯的是有 angular 的服務注入錯誤 (只是不知道是哪個= =)

未命名

另一方面造成的原因是因為 webpack -p 會使用一個設定 mangle: true

會將變數名稱用單一字母做替換,以減小 js 檔案大小。

(因此把 mangle 這個功能改為 false 就可以解決,只是有點消極,而且這樣相對壓縮有限)

但可想而知我們注入的 angular 服務

如:

[javascript]

app.contorller(‘test’, function($scope, $http) {

…程式碼 });

[/javascript]

這其中的 $scope 及 $http 也會被替換為其他字母,導致無法正確地注入服務,因此造成了這些錯誤。


解決方法為我們必須用angular 嚴謹一點的寫法來正確注入服務

  1. 當我們需要注入服務時,需要在前依序標明注入的服務 如:

    [javascript]

    app.contorller(‘test’, [‘$scope’, ‘$http’, function($scope, $http) {

    …程式碼 }]);

    [/javascript]

  2. 利用 $inject 注入相依賴的服務 如:

    [javascript]

    var MyController = function($scope, greeter) { // … } MyController.$inject = [‘$scope’, ‘greeter’]; [/javascript]

PS. 若有相對應的參數,也需要用此 inject 的寫法注入

這樣就可以成功的打包 angular 的 js 檔

參考資料:

https://docs.angularjs.org/guide/di