一个@NgModule装饰器,可以在Angular1.x中使用,它只有2kb,但是却能够有效的缩短开发周期,降低模块间的耦合度,使代码更加简洁。
npm安装:
npm install --save ng1-module-decorator
或 cnpm install --save ng1-module-decorator
具体的代码示例请查看/example/
目录下的代码,这里做一个简要的说明:
//导入模块装饰器
import NgModule from 'ng1-module-decorator';
//或 let NgModule = require('ng1-module-decorator');
//配置块和运行块
import { appConfig } from './app.config';
import { appRun } from './app.run';
//app组件
import { appComponent } from './component/app/app.component';
import { appState } from './component/app/app.state';
//home组件
import { homeComponent } from './component/home/home.component';
import { homeState } from './component/home/home.state';
//控制器
import { myController } from './share/controllers/myController';
//指令
import { greeting } from './share/directives/greeting';
//过滤器
import { replaceHello } from './share/filters/replaceHello';
//服务
import { greetService } from './share/services/greetService';
import { apiPath } from './share/services/apiPath';
import { colorService } from './share/services/colorService';
@NgModule({
name: 'app', //模块名,必填
imports: ['ui.router'], //导入模块,根模块必须导入uiRouter模块,其他可选
configBlocks: [appConfig], //配置块函数,可选
runBlocks: [appRun], //运行块函数,可选
states: [ //路由状态,可选
appState,
homeState
],
components: { //组件,可选
appComponent,
homeComponent
},
directives: {greeting}, //指令,可选
controllers: {myController}, //控制器,可选
filters: {replaceHello}, //过滤器,可选
providers: {colorService}, //提供者,可选
services: {greetService}, //服务,可选
constants: {apiPath}, //常量服务,可选
decorators: {} //装饰器,可选
})
class Module {}
//导出模块:通过name属性导出模块,不用需要关注模块名是什么
export const AppModule = new Module().name;
元数据name必须指定,它代表了模块的名字;根模块必须导入ui.router模块,因为state元数据使用到了这个模块的功能;其他元数据都是可选的,可以不填,填一个或者多个。
- AngularJS版本1.5.x以上
- uiRouter模块
该项目使用到了ES6的装饰器功能,因此需要babel进行编译才能运行,这里给出一个.babelrc文件的一个配置,具体的编译配置可参考\example\
。
{
"presets": [
"es2015",
"stage-0"
],
"plugins": [
"transform-decorators-legacy"
],
"env": {
"test": {
"plugins": [
"istanbul"
]
}
}
}
在webpack.config.js文件中,还要把node_modules/ng1-api-service加入编译列表中。
{
test: /\.js$/,
use: {
loader: "babel-loader"
},
include: [
path.resolve(__dirname, 'example'),
path.resolve(__dirname, 'core'),
/node_modules(?!\/ng1-module-decorator)/
]
}
cd ng1-module-decorator
npm install
npm run server
然后会自动运行项目并打开浏览器。
该项目指定了一些必须的依赖,但是你可以fork该项目,并改动源码来适应你自己的项目。相信我这会很轻松,因为它真的很小,只有几十行的代码。