Нужен ли мне ROUTER_DIRECTIVE в каждом компоненте angular2 RC4?

Я создаю приложение angular 2. Он небольшой, состоит из 3-5 компонентов и основан на учебнике. Я научился делиться датой через Service более чем с одним Component, добавляя ее в массив функции bootsrap в моем main.ts.

Есть что-то подобное для ROUTER_DIRECTIVES. Я хочу сделать все мои маршруты доступными для всех компонентов. Я хочу добавить routerLinks в некоторые шаблоны, но если я не добавлю ROUTER_DIRECTIVES в массив директив в качестве метаданных для компонента, я не смогу использовать routerLink.

Мой вопрос: могу ли я избежать этого фрагмента, определив глобальный ROUTER_DIRECTIVES для каждого компонента в моем приложении?

@Component({
  selector: 'players',
  templateUrl: 'app/players.html',
  directives: [ROUTER_DIRECTIVES]
})
export class PlayersComponent {}

person DenniJensen    schedule 04.08.2016    source источник


Ответы (2)


В настоящее время (RC.4) вы можете сделать

bootstrap(AppComponent, 
    [{provide: PLATFORM_DIRECTIVES, useValue: [ROUTER_DIRECTIVES], multi: true}]);

Со следующим обновлением (RC.5) и введением модулей вы можете предоставить директивы для всего модуля.

person Günter Zöchbauer    schedule 05.08.2016

Если вы используете 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
        })
    ])
};
person null canvas    schedule 05.08.2016