Angular.js: Function.prototype.bind.apply(...) ist kein Konstruktor

Erstellt am 22. Juni 2016  ·  2Kommentare  ·  Quelle: angular/angular.js

Ich versuche Winkel-tdd zu lernen

Mit diesen Versionen funktionieren meine Tests einwandfrei
Abhängigkeitsversion
eckig: 1.4.8
eckig-spott: 1.4.8
Knoten: v4.4.5
Karma-Kli: 0.13.22

aber wenn ich benutze
Versionen
"eckig": "^1.5.7"
"angular-mocks": "^1.5.7"

es wirft einen Fehler

karma start karma.conf.js

22 06 2016 16:53:04.002:WARN [karma]: No captured browser, open http://localhost:9876/
22 06 2016 16:53:04.012:INFO [karma]: Karma v0.13.22 server started at http://localhost:9876/
22 06 2016 16:53:04.018:INFO [launcher]: Starting browser Chrome
22 06 2016 16:53:05.959:INFO [Chrome 51.0.2704 (Linux 0.0.0)]: Connected on socket /#Vfy_Fpt6BZ2INRyEAAAA with id 36097936
Chrome 51.0.2704 (Linux 0.0.0) calculator sum 1 + 1 should equal 2 FAILED
    TypeError: Function.prototype.bind.apply(...) is not a constructor
        at Object.instantiate (/home/malanay/workspace/AngularJs-BDD-101/node_modules/angular/angular.min.js:41:477)
        at /home/kiro112/workspace/AngularJs-BDD-101/node_modules/angular/angular.min.js:90:3
        at /home/kiro112/workspace/AngularJs-BDD-101/node_modules/angular-mocks/angular-mocks.js:2214:12
        at Object.it (/home/kiro112/workspace/AngularJs-BDD-101/tests/calculator.controller.test.js:17:21)
Chrome 51.0.2704 (Linux 0.0.0): Executed 1 of 1 (1 FAILED) (0 secs / 0.027 Chrome 51.0.2704 (Linux 0.0.0): Executed 1 of 1 (1 FAILED) ERROR (0.037 secs / 0.027 secs)
invalid

Hilfreichster Kommentar

Das Problem besteht darin, den Funktionskonstruktor für die Controller-Klasse mit der Fat Arrow-Syntax zu definieren. Angenommen, Ihre als zweites Argument an module.controller übergebene Funktion ist Foo , Angular ruft new Foo(...) auf, was mit der Fat Arrow-Syntax in ES6 illegal ist.

Alle 2 Kommentare

Das Problem besteht darin, den Funktionskonstruktor für die Controller-Klasse mit der Fat Arrow-Syntax zu definieren. Angenommen, Ihre als zweites Argument an module.controller übergebene Funktion ist Foo , Angular ruft new Foo(...) auf, was mit der Fat Arrow-Syntax in ES6 illegal ist.

@wesleycho , hat recht. Controller sollten instanziierbar sein (dh mit new aufgerufen werden), also sind Dinge wie Pfeilfunktionen ( () => {...} ) und Kurzform-Objektmethoden ( {someMethod() {...}} ) nicht für Controller geeignet.

Weitere Informationen finden Sie unter https://github.com/angular/angular.js/issues/14766#issuecomment -226005516.

War diese Seite hilfreich?
0 / 5 - 0 Bewertungen