我正在研究练习angularJS的个人项目,但是我遇到了一个无法解决的问题。
当我提交表单时,我想在submitLogin()
中使用LoginCtrl.js
函数,但Safari浏览器中的错误控制台表示$scope.submitLogin
为readonly 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')
}
}
}])
答案 0 :(得分:1)
问题是我没有在$http.get
中返回LoginService.js
这就是Login.getToken()
不是对象的原因