无法读取未定义的属性。如何定义?
我想在Angularjs中运行一个自定义的PUT,但是我无法让我的生活得到它的工作。我需要定义UserResource和user,但只有更新函数第一个位置的参数被定义。我能做些什么来定义用户和UserResource?无法读取未定义的属性。如何定义?
(function() {
class AdminController {
constructor(User, Auth) {
this.users = User.query();
this.Auth = Auth;
}
//here user is defined and I can run the delete function
delete(user) {
user.$remove();
this.users.splice(this.users.indexOf(user), 1);
}
// and if I put user into the first position it is defined but UserResource isn't
// as written here it isn't defined either.
update(UserResource, user) {
var $id = user._id;
UserResource.update({ id:$id }, user);
}
}
angular.module('wcsdesktopApp.admin')
.controller('AdminController', AdminController);
})();
编辑添加的更多信息
我所说的更新功能是这样的:
<table>
<tr>
<a ng-click="admin.update(user)" class="update"><span class="fa fa-refresh fa-2x"></span></a>
</tr>
<tr>
<a ng-click="admin.delete(user)" class="trash"><span class="fa fa-trash fa-2x"></span></a>
</tr>
</table>
我列入参考删除功能,因为这是工作。
UserResource是AngularJS $resource自定义放置请求。
(function() {
function UserResource($resource) {
return $resource('/api/users/:id/:controller', {
id: '@_id'
}, {
changePassword: {
method: 'PUT',
params: {
controller: 'password'
}
},
update: {
method: 'PUT'
},
get: {
method: 'GET',
params: {
id: 'me'
}
}
});
}
angular.module('wcsdesktopApp.auth')
.factory('User', UserResource);
})();
您需要确保您将UserResource
服务注入到您的控制器中。其中的很多方面会像下面:
angular.module('wcsdesktopApp.admin').controller('AdminController', AdminController);
AdminController.$inject = [ 'User'];
function AdminController(User) {}
这样做,那么这将在您的控制器更改update
签名如下:
update(user) {
User.update(); // Do whatever update.
}
我实现了你建议的代码。我回来 'ReferenceError:UserResource未定义' – Rarepuppers
我错过了您命名服务'用户'但功能'UserResource'的事实。我已经更新了答案,以反映这一点,但您可能需要考虑将它们命名为相同以清楚说明您所调用的内容。 –
对不起,很麻烦,但是,我在更新的答案中遵循了你的建议,并将名称标准化为'User',我仍然得到相同的错误。 – Rarepuppers
你是如何调用'update'? 'UserResource'应该是某种服务吗? –
我用更多的信息更新了这个问题。让我知道如果有帮助 – Rarepuppers
你必须注入你的服务到你的控制器。这就是为什么这个部分不起作用。我可以给你一个完整的答案。 –