Angular.js: Function.prototype.bind.apply (...) não é um construtor

Criado em 22 jun. 2016  ·  2Comentários  ·  Fonte: angular/angular.js

Estou tentando aprender angular-tdd

com essas versões meus testes estão funcionando bem
versão das dependências
angular: 1.4.8
simulações angulares: 1.4.8
nó: v4.4.5
karma-cli: 0.13.22

mas quando eu uso
versões
"angular": "^ 1.5.7"
"simulações angulares": "^ 1.5.7"

lança um erro

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

Comentários muito úteis

O problema é usar a sintaxe de seta grande para definir o construtor de função para a classe do controlador. Assumindo que sua função passada como o segundo argumento para module.controller seja Foo , o Angular chamará new Foo(...) nela, o que é ilegal com a sintaxe de seta grossa no ES6.

Todos 2 comentários

O problema é usar a sintaxe de seta grande para definir o construtor de função para a classe do controlador. Assumindo que sua função passada como o segundo argumento para module.controller seja Foo , o Angular chamará new Foo(...) nela, o que é ilegal com a sintaxe de seta grossa no ES6.

@wesleycho , está certo. Os controladores devem ser instanciados (isto é, chamados com new ), então coisas como funções de seta ( () => {...} ) e métodos de objetos abreviados ( {someMethod() {...}} ) não são adequados para controladores.

Consulte https://github.com/angular/angular.js/issues/14766#issuecomment -226005516 para obter mais detalhes.

Esta página foi útil?
0 / 5 - 0 avaliações