Подтвердить что ты не робот

Angular 2: Не удается прочитать свойство 'validator' из undefined

Хорошо, так что это официально сводит меня с ума теперь.

В настоящее время у меня есть два компонента в моем приложении Angular 2, каждый из которых содержит форму. Форма регистрации работает нормально, но у меня возникают проблемы с моей подписью. Совсем недавно я использовал компонент signup в качестве шаблона для компонента signin, просто чтобы попытаться найти проблему.

Я обрезал все, кроме самого необходимого кода, как из класса компонента, так и из шаблона компонента. В настоящее время мой шаблон компонента выглядит следующим образом:

<link href="css/animation.css" rel="stylesheet">

<section id="signin_alt" class="authenty signin-alt">
    <form [ngFormModel]="signinForm" novalidate>
    </form>
</section>

Мой класс компонентов выглядит следующим образом:

import { Component } from 'angular2/core';
import { ControlGroup, FormBuilder, AbstractControl, Validators } from 'angular2/common';
import { RouterOutlet, RouterLink, RouteConfig, Router, ROUTER_DIRECTIVES } from 'angular2/router';
import { AuthenticationService } from './services/authentication.service';
import { AppComponent } from '../app.component';

@Component({
    selector: 'signin',
    directives: [RouterOutlet, RouterLink],
    template: require('./signin.component.html')
})
export class SigninComponent {
    signinForm: ControlGroup;
}

Если я удалю [ngFormModel] из формы, это не вызовет ошибок. Когда я добавляю атрибут, я получаю этот вкусный результат:

EXCEPTION: TypeError: Cannot read property 'validator' of undefined in [signinForm in [email protected]:14]

Для полноты, вот моя конфигурация webpack:

var sliceArgs = Function.prototype.call.bind(Array.prototype.slice);
var toString = Function.prototype.call.bind(Object.prototype.toString);
var path = require('path');
var webpack = require('webpack');

module.exports = {
    devtool: 'source-map',
    debug: true,
    devServer: {
        historyApiFallback: true,
        contentBase: 'src/public',
        publicPath: '/__build__'
    },
    entry: {
        'app': './src/app/bootstrap',
        'vendor': './src/app/vendor.ts'
    },
    output: {
        path: root('public/__build__'),
        filename: '[name].js',
        sourceMapFilename: '[name].js.map',
        chunkFilename: '[id].chunk.js'
    },
    resolve: {
        extensions: ['', '.ts', '.js', '.json', '.css', '.html']
    },
    module: {
        loaders: [
            { test: /\.json$/, loader: 'json' },
            { test: /\.css$/, loader: "style-loader!css-loader" },
            { test: /\.png$/, loader: "url-loader?limit=100000" },
            { test: /\.jpg$/, loader: "file-loader" },
            { test: /\.html$/, loader: 'html' },
            {
                test: /\.ts$/,
                loader: 'ts',
                exclude: [/\.spec\.ts$/, /\.e2e\.ts$/, /node_modules/]
            },
            {
                test: /\.scss$/,
                loaders: ['style', 'css?sourceMap', 'sass?sourceMap']
            },
            {
                test: /\.(woff|woff2)(\?v=[0-9]\.[0-9]\.[0-9])?$/,
                loader: "url-loader?limit=10000&minetype=application/font-woff"
            },
            {
                test: /\.(ttf|eot|svg)(\?v=[0-9]\.[0-9]\.[0-9])?$/,
                loader: "file-loader"
            }
        ]
    },
    plugins: [
        new webpack.optimize.CommonsChunkPlugin({ name: 'vendor', filename: 'vendor.bundle.js' }),
        new webpack.ProvidePlugin({ $: "jquery", jQuery: "jquery" })
    ]
};

function root(args) {
    args = sliceArgs(arguments, 0);
    return path.join.apply(path, [__dirname].concat(args));
}

function rootNode(args) {
    args = sliceArgs(arguments, 0);
    return root.apply(path, ['node_modules'].concat(args));
}

Посмотрев на трассировку стека, кажется, что форма не создается. Ошибка в этой функции Angular:

NgFormModel.prototype.ngOnChanges = function (changes) {
    if (collection_1.StringMapWrapper.contains(changes, "form")) {
        var sync = shared_1.composeValidators(this._validators);
        this.form.validator = validators_1.Validators.compose([this.form.validator, sync]);
        var async = shared_1.composeAsyncValidators(this._asyncValidators);
        this.form.asyncValidator = validators_1.Validators.composeAsync([this.form.asyncValidator, async]);
        this.form.updateValueAndValidity({ onlySelf: true, emitEvent: false });
    }
    this._updateDomValue();
};

где 'this.form' имеет значение null.

Может ли кто-нибудь пролить свет на это? Я исчерпал свои знания Angular 2 в поисках решения!

Спасибо.

4b9b3361

Ответ 1

Вы создаете экземпляр внутри объекта signinForm в компоненте SigninComponent, поскольку вы используете директиву ngFormModel. Что-то вроде этого (например):

constructor(_builder:FormBuilder) {
  this.signinForm = _builder.group({
        login: ['', Validators.required],
        password: ['', Validators.required]
});

Надеюсь, это поможет вам, Thierry