我是否需要 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) 和模块的引入,您可以为整个模块提供指令。