又一周过去了,项目也已经作得有点模样了。收集来一些小经验,分享给你们,有疏漏之处,还望指正,海涵。
上周整合了gulp与webpack,那么工具准备差很少了,咱们就开始编码吧。编码的框架就是angular了(如今已经出了es6了,配合angular2其实很酷,有兴趣的朋友们去玩喽,这里仍是angular1)。
从哪开始呢?对的,咱们要先有个angular。还要能让webpack经过一句:html
require('angular');
完成导入。这样的话我就先去官网下载了一个angular.js文件,而后在个人webpack的入口文件index.js里这样写:java
require('./angular.js');
事实证实这样写是错的。。。而后我就看网上的哥哥们怎么写,他们的代码里都是直接这样:webpack
require('angular');
我就用npm来安装了一个angulargit
npm install --save-dev angular
而后,我在index.js里这样写:es6
var angular = require('angular');
var App = angular.module("App",[]);
ok,这样就对了。那么咱们接下来要给angular加个ui-router的插件。那就采用相同的办法了:
首先要:github
npm install --save-dev angular-ui-router
而后:web
var angular = require('angular');
var uiRouter = require('angular-ui-router');
var App = angular.module("App",[uiRouter ]);
这样没有问题,能够简写一下:npm
var angular = require('angular');
var App = angular.module("App",[
require('angular-ui-router')
]);
那么咱们自定义的module要怎么加入到App的依赖中去呢?咱们本身写的又不能用npm去安装。
假如我在index.js(webpack的入口文件)的同级目录下,有个文件夹modules,里边放的是写好的模块文件如myModule.js,这是一次有益的尝试:gulp
var angular = require('angular');
var App = angular.module("App",[
require('angular-ui-router'),
require('./modules/myModule.js')
]);
myModule.js的内容以下:ruby
var angular = require('angular');
/** * 这里是***模块 * @type {[type]} */
var myModule = angular.module('myModule', []);
myModule.controller('myModuleCtrl',function($scope,$http,$state,$stateParams) {
//这里是controller的内容
});
这样呢,又会报错了。为何呢?由于webpack导入的模块要符合CMD或者AMD的规范,而这个module显然是不符合的。关于规范:webpack教程与规范
那么搞懂了这个规范的意思,那也就是说,咱们这个myModule应该这样写:
var angular = require('angular');
/** * 这里是***模块 * @type {[type]} */
var myModule = angular.module('myModule', []);
myModule.controller('myModuleCtrl',function($scope,$http,$state,$stateParams) {
//这里是controller的内容
});
module.exports = myModule;
试了一下,仍是不行啊报这个错:“module-is-not-a-function”,又去stackOverflow上查了一下:如何解决module is not a function 1 以及:如何解决module is not a function 2
原来是导出的时候加上.name,像这样:
module.exports = myModule.name;
基本上能够跑起来了。
这里还有一个坑,已经填上了:unknow provider使用ngAnnotate来解决:ngAnnotate的git地址 好的,到此为止,咱们已经能让angular在webpack的环境下运行起来了。