AngularJS:错误:尝试在ng-submit指令

时间:2016-06-13 05:21:06

标签: javascript html angularjs

我正在研究练习angularJS的个人项目,但是我遇到了一个无法解决的问题。

当我提交表单时,我想在submitLogin()中使用LoginCtrl.js函数,但Safari浏览器中的错误控制台表示$scope.submitLoginreadonly property,因此我可以&#39 ;弄清楚什么是错的。

如何解决readonly属性错误?是什么导致了这个错误?

我收到如下错误:

Error: Attempted to assign to readonly property.
http://localhost:8080/js/controllers/LoginCtrl.js:6:13
[native code]
instantiate@http://localhost:8080/libs/angular/angular.js:4723:61
$controller@http://localhost:8080/libs/angular/angular.js:10192:39
link@http://localhost:8080/libs/angular-route/angular-route.js:1017:37
http://localhost:8080/libs/angular/angular.js:1266:23
invokeLinkFn@http://localhost:8080/libs/angular/angular.js:9757:15
nodeLinkFn@http://localhost:8080/libs/angular/angular.js:9156:23
compositeLinkFn@http://localhost:8080/libs/angular/angular.js:8459:23
publicLinkFn@http://localhost:8080/libs/angular/angular.js:8339:45
lazyCompilation@http://localhost:8080/libs/angular/angular.js:8677:30
boundTranscludeFn@http://localhost:8080/libs/angular/angular.js:8476:28
controllersBoundTransclude@http://localhost:8080/libs/angular/angular.js:9206:37
update@http://localhost:8080/libs/angular-route/angular-route.js:975:36
$broadcast@http://localhost:8080/libs/angular/angular.js:17701:33
http://localhost:8080/libs/angular-route/angular-route.js:615:36
processQueue@http://localhost:8080/libs/angular/angular.js:16104:30
http://localhost:8080/libs/angular/angular.js:16120:39
$eval@http://localhost:8080/libs/angular/angular.js:17378:28
$digest@http://localhost:8080/libs/angular/angular.js:17191:36
$apply@http://localhost:8080/libs/angular/angular.js:17486:31
done@http://localhost:8080/libs/angular/angular.js:11637:53
completeRequest@http://localhost:8080/libs/angular/angular.js:11843:15
requestLoaded@http://localhost:8080/libs/angular/angular.js:11776:24 – "<div ng-view=\"\" class=\"ng-scope\">"

index.html(仅限javascript包含部分)

...
  <!-- JS -->
  <script src="libs/angular/angular.js"></script>
  <script src="libs/angular-route/angular-route.js"></script>
  <script src="libs/angular-cookies/angular-cookies.js"></script>


  <!-- ANGULAR COMSTOM -->
  <script src="js/controllers/MainCtrl.js"></script>
  <script src="js/controllers/NerdCtrl.js"></script>
  <script src="js/controllers/LoginCtrl.js"></script>
  <script src="js/services/NerdService.js"></script>
  <script src="js/services/ReviewService.js"></script>
  <script src="js/services/LoginService.js"></script>
  <script src="js/appRoutes.js"></script>
  <script src="js/app.js"></script>
</head>

<body ng-app="sampleApp">
...

appRoutes.js //负责路由的控制器

angular.module('appRoutes', []).
  config(['$routeProvider', '$locationProvider', function($routeProvider, $locationProvider){

    $routeProvider
      .when('/', {
        templateUrl: 'views/home.html',
        controller: 'MainController'
      })
      .when('/login', {
        templateUrl: 'views/login.html',
        controller: 'LoginController'
      });


    $locationProvider.html5Mode(true);
  }]);

的login.html

<div class = "row" >
  <div class= "col-md-4 col-md-offset-4">
    <h3 class = "text-center">LOGIN</h3>
    <form ng-submit="submitLogin()">    // <-
      <div class = "form-group">
        <div class="input-group">
          <span class = "input-group-addon">
            <i class="fa fa-envelope-o"></i>
          </span>
          <input id = "login_email" type="text" name="name" class="form-control input-lg" placeholder="Email"
          ng-model="login.email" required>
        </div>
      </div>

      <div class="form-group">
        <div class="input-group">
          <span class="input-group-addon">
            <i class="fa fa-asterisk" aria-hidden="true"></i>
          </span>
          <input id="login_password" type="password" name="password" class="form-control input-lg"
          placeholder="Password" ng-model="login.password" required>
        </div>
      </div>

      <button type="submit" class="btn btn-primary btn-lg btn-block btn-shadow">Login</button>
    </form>
  </div>
</div>

LoginCtrl.js

'use strict';

angular.module('LoginCtrl', ['LoginService', 'ngCookies'])
  .controller('LoginController', [
    function($scope, Login, $cookieStore) {
      $scope.submitLogin = function() {
        Login.getToken($scope.login.email, $scope.login.password)
          .then(function(response) {

            if(response.data['success'] == true) {
              $scope.token = response.data['token'];
              $cookieStore.put('Token', $scope.token);
              //$window.alert($cookieStore.get('Token'));
            }
            else {
              $scope.token = null;
            }
        })};
}]);

LoginService.js

angular.module('LoginService', []).factory('Login', ['$http', function($http) {
  return {
    getToken : function(name, password) {
      var data = { name: name, password: password}
      $http.get('/authenticate', data);
    },

    getAllUsers: function(token) {
      $http.get('/users')
    }
  }
}])

1 个答案:

答案 0 :(得分:1)

问题是我没有在$http.get中返回LoginService.js这就是Login.getToken()不是对象的原因