我是否需要 ROUTER_DIRECTIVE 在 angular2 RC4 的每个组件中?
Do I need the ROUTER_DIRECTIVE in every component in angular2 RC4?
我正在构建一个 angular 2 应用程序。是一个小的,有 3 到 5 个组件,并且基于教程。
我学会了如何通过 Service
为多个 Component
共享日期,方法是将日期添加到我的 main.ts
.
中的 bootsrap
函数数组中
ROUTER_DIRECTIVES
有类似的东西吗?我想让所有组件都可以使用我的所有路由。我想在一些模板中添加 routerLinks
,但如果我不将 ROUTER_DIRECTIVES
作为组件的元数据添加到指令数组中,我将无法使用 routerLink。
我的问题是,我可以通过为应用程序中的每个组件定义一个全局 ROUTER_DIRECTIVES
来避免此代码段吗?
@Component({
selector: 'players',
templateUrl: 'app/players.html',
directives: [ROUTER_DIRECTIVES]
})
export class PlayersComponent {}
如果您使用 webpack
打包您的应用程序,我认为您可以将其配置为默认包含 [ROUTER_DIRECTIVES]
:
var path = require('path');
var webpack = require('webpack');
var ExtractTextPlugin = require('extract-text-webpack-plugin');
var extractCSS = new ExtractTextPlugin('vendor.css');
var isDevelopment = process.env.ASPNETCORE_ENVIRONMENT === 'Development';
module.exports = {
resolve: {
extensions: [ '', '.js' ]
},
module: {
loaders: [
{ test: /\.(png|woff|woff2|eot|ttf|svg)$/, loader: 'url-loader?limit=100000' },
{ test: /\.css/, loader: extractCSS.extract(['css']) }
]
},
entry: {
vendor: [
'bootstrap',
'bootstrap/dist/css/bootstrap.css',
'es6-shim',
'style-loader',
'jquery',
'@angular/common',
'@angular/compiler',
'@angular/core',
'@angular/http',
'@angular/platform-browser',
'@angular/platform-browser-dynamic',
'@angular/router',
'@angular/platform-server',
]
},
output: {
path: path.join(__dirname, 'wwwroot', 'dist'),
filename: '[name].js',
library: '[name]_[hash]',
},
plugins: [
extractCSS,
new webpack.ProvidePlugin({ $: 'jquery', jQuery: 'jquery' }), // Maps these identifiers to the jQuery package (because Bootstrap expects it to be a global variable)
new webpack.optimize.OccurenceOrderPlugin(),
new webpack.DllPlugin({
path: path.join(__dirname, 'wwwroot', 'dist', '[name]-manifest.json'),
name: '[name]_[hash]'
})
].concat(isDevelopment ? [] : [
new webpack.optimize.UglifyJsPlugin({
compress: { warnings: false },
minimize: true,
mangle: false // Due to https://github.com/angular/angular/issues/6678
})
])
};
目前(RC.4)你可以做
bootstrap(AppComponent,
[{provide: PLATFORM_DIRECTIVES, useValue: [ROUTER_DIRECTIVES], multi: true}]);
随着下一次更新 (RC.5) 和模块的引入,您可以为整个模块提供指令。
我正在构建一个 angular 2 应用程序。是一个小的,有 3 到 5 个组件,并且基于教程。
我学会了如何通过 Service
为多个 Component
共享日期,方法是将日期添加到我的 main.ts
.
bootsrap
函数数组中
ROUTER_DIRECTIVES
有类似的东西吗?我想让所有组件都可以使用我的所有路由。我想在一些模板中添加 routerLinks
,但如果我不将 ROUTER_DIRECTIVES
作为组件的元数据添加到指令数组中,我将无法使用 routerLink。
我的问题是,我可以通过为应用程序中的每个组件定义一个全局 ROUTER_DIRECTIVES
来避免此代码段吗?
@Component({
selector: 'players',
templateUrl: 'app/players.html',
directives: [ROUTER_DIRECTIVES]
})
export class PlayersComponent {}
如果您使用 webpack
打包您的应用程序,我认为您可以将其配置为默认包含 [ROUTER_DIRECTIVES]
:
var path = require('path');
var webpack = require('webpack');
var ExtractTextPlugin = require('extract-text-webpack-plugin');
var extractCSS = new ExtractTextPlugin('vendor.css');
var isDevelopment = process.env.ASPNETCORE_ENVIRONMENT === 'Development';
module.exports = {
resolve: {
extensions: [ '', '.js' ]
},
module: {
loaders: [
{ test: /\.(png|woff|woff2|eot|ttf|svg)$/, loader: 'url-loader?limit=100000' },
{ test: /\.css/, loader: extractCSS.extract(['css']) }
]
},
entry: {
vendor: [
'bootstrap',
'bootstrap/dist/css/bootstrap.css',
'es6-shim',
'style-loader',
'jquery',
'@angular/common',
'@angular/compiler',
'@angular/core',
'@angular/http',
'@angular/platform-browser',
'@angular/platform-browser-dynamic',
'@angular/router',
'@angular/platform-server',
]
},
output: {
path: path.join(__dirname, 'wwwroot', 'dist'),
filename: '[name].js',
library: '[name]_[hash]',
},
plugins: [
extractCSS,
new webpack.ProvidePlugin({ $: 'jquery', jQuery: 'jquery' }), // Maps these identifiers to the jQuery package (because Bootstrap expects it to be a global variable)
new webpack.optimize.OccurenceOrderPlugin(),
new webpack.DllPlugin({
path: path.join(__dirname, 'wwwroot', 'dist', '[name]-manifest.json'),
name: '[name]_[hash]'
})
].concat(isDevelopment ? [] : [
new webpack.optimize.UglifyJsPlugin({
compress: { warnings: false },
minimize: true,
mangle: false // Due to https://github.com/angular/angular/issues/6678
})
])
};
目前(RC.4)你可以做
bootstrap(AppComponent,
[{provide: PLATFORM_DIRECTIVES, useValue: [ROUTER_DIRECTIVES], multi: true}]);
随着下一次更新 (RC.5) 和模块的引入,您可以为整个模块提供指令。