24

ログインボタンをクリックしたときにログイン機能を呼び出したいのですが、タイトルにエラーメッセージが表示され続けます。誰かが私のスクリプトのエラーを指摘できますか?

以下の login.js コード:

/*global Firebase, angular, console*/

'use strict';
// Create a new app with the AngularFire module
var app = angular.module("runsheetApp");

app.controller("AuthCtrl", function ($scope, $firebaseAuth) {
    var ref = new Firebase("https://xxxxx.firebaseio.com");
    function login() {
        ref.authWithPassword({
            email    : "xxxxx",
            password : "xxxx"
        }, function (error, authData) {
            if (error) {
                console.log("Login Failed!", error);
            } else {
                console.log("Authenticated successfully with payload:", authData);
            }
        });
    }
});
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.21/angular.min.js"></script>

また、login.html のコードも以下のとおりです。

<div class="container" style="max-width: 300px">
    <form class="form-signin">       
      <h2 class="form-signin-heading" style="text-align: center">Please Sign In</h2>
      <input type="text" class="form-control" name="username" ng-model = "username" placeholder="Email Address" required="" autofocus="" />
        </br>
      <input type="password" class="form-control" name="password" ng-model = "password" placeholder="Password" required=""/>
        </br>
      <button class="btn btn-lg btn-primary btn-block" type="submit" ng-click="login()">Login</button>   
    </form>
  </div>

4

8 に答える 8

66

ここではエッジケースですが、後世のために言及したいと思います。nameと同じ値を持つフォームで controllerAs パターンを使用すると、この同じエラーが発生しましたng-submit。例えば:

<form name="authCtrl.signUp" ng-submit="authCtrl.signUp()">

スロー: TypeError: v2.signUp は関数ではありません

解決策は、フォームの名前を別のものに変更することでした:

<form name="authCtrl.signUpForm" ng-submit="authCtrl.signUp()">

于 2015-09-30T19:49:29.930 に答える
20

私の場合、私はあなたとまったく同じ問題を抱えていました。しかし、そのようなシナリオに対する gkalpak の回答に出くわしたことは、私を助けてくれました。

私が呼び出していたのは、「addBuddy」という名前のフォームからの addBuddy() 関数であることが判明しました。解決策は、2 つのもののいずれかの名前を変更して、一方を目立つようにするか、他方と区別できるようにすることでした。フォームの名前を「addBuddyForm」に変更すると、出来上がりです! 私の機能が働いた!

これが私のケースのスニペットです:

<form name="addBuddy" class="form-horizontal" novalidate>
...
<button class="btn btn-sm btn-info" ng-click="addBuddy()>Submit</button>

どちらに変更しました:

<form name="addBuddyForm" class="form-horizontal" novalidate>
...
<button class="btn btn-sm btn-info" ng-click="addBuddy()>Submit</button>

...そしてうまくいきました!:)

于 2017-10-16T11:06:41.757 に答える
11

AngularJS では、ビューから関数を呼び出します。これは $scope 内にある必要があります。

JS

// exposes login function in scope
$scope.login = login;

HTML

<div class="container" ng-controller="AuthCtrl" style="max-width: 300px"> <!-- I notice here for include ng-controller to your main div -->
<form class="form-signin">       
  <h2 class="form-signin-heading" style="text-align: center">Please Sign In</h2>
  <input type="text" class="form-control" name="username" ng-model = "username" placeholder="Email Address" required="" autofocus="" />
    </br>
  <input type="password" class="form-control" name="password" ng-model = "password" placeholder="Password" required=""/>
    </br>
  <button class="btn btn-lg btn-primary btn-block" type="submit" ng-click="login()">Login</button>   
</form>

于 2015-08-14T07:05:16.363 に答える
7

これはあなたの問題に固有のものではないかもしれませんが、私もこのエラーを受け取っていて、その理由を理解するのに少し時間がかかりました.

関数と変数の両方に同じ名前を付け、変数を関数に割り当てたため、変数の割り当てが関数をオーバーライドし、2回目の実行で爆発していました。

この例では、uploadFile() 関数が upload.uploadFile = true; になっていることに気付くでしょう。これは、upload.uploadingFile (スピナーの動作を制御するために使用されるフラグ) を意図した素晴らしいファイルでした。それが修正されると、問題は解消されました。

例:

(function()
{
  'use strict';

  angular.module('aumApp.file-upload')
  .controller('FileUploadCtrl', FileUploadCtrl);

  function FileUploadCtrl($scope, $http)
  {
    upload.uploadFile = function()
    {
      upload.uploadFile = true;
      var backendUrl = '/ua_aumcore/events/api/v1/events/uploadFile';
      var fd = new FormData();
      fd.append('file', upload.src);
      $http({ url: backendUrl, data: fd, method: 'POST', transformRequest : angular.identity, headers: { 'Content-Type' : undefined } })
      .then(function uploadSuccess(response)
      {
        upload.data = response.data;
        upload.message = "Uploaded Succesfully.";
        upload.uploadSuccess = true;
        upload.uploadingFile = false;
      },
      function uploadFailure(response)
      {
        upload.message = "Upload Failed.";
        upload.uploadSuccess = false;
        upload.uploadingFile = false;
      });
    };
  }
  FileUploadCtrl.$inject = ['$scope', '$http'];
})();
于 2016-08-02T13:44:25.087 に答える
5

ビューから呼び出し可能にするには、関数が $scope 内にある必要があります。追加

$scope.login = login;

コントローラーのJSコードに。

また、実際にそのコントローラーを使用する必要があります。変化する

<div class="container" style="max-width: 300px">

<div ng-controller="AuthCtrl" class="container" style="max-width: 300px">

これはすべて基本的なことです。先に進む前に、AngularJS のチュートリアルから学ぶことをお勧めします。

于 2015-08-14T06:21:40.343 に答える