我试图将一个resolve值绑定到angularjs 1.5组件,但没有成功,在状态定义中,我已将模板属性的通用值替换为新组件名称的值。像这样:
.state('eventslogs.create', {
url: '/create',
template: '<addevent data="$resolve.addevent"></addevent>.',
resolve: {
addevent: newEventslog
},
data: {
roles: ['admin'],
pageTitle: 'Eventslogs Create'
}
})
NewEventslog是一个注入我的服务之一的函数
newEventslog.$inject = ['EventslogsService'];
function newEventslog(EventslogsService) {
return new EventslogsService();
}
在我的控制器中,我尝试了几种方法,但没有任何效果
angular.module('eventslogs')
.component('addevent', {
templateUrl: 'addevent.client.component.view.html',
bindings: {
data: '<'
},
controller: function($scope, $element) {
var vm = this;
vm.eventslog = vm.data;
}
但是vm.eventslog总是导致未定义的值,我的方法有什么问题?如果在绑定中使用“ @”而不是“ <”,则vm.addevent会产生一个字符串,其值是“ $ resource.addevent”,而不像newEventslog函数的实例。
我正在使用ui-route版本0.2.18
不确定,但可以在组件内部尝试
this.$onInit = () => {
vm.eventslog = vm.data;
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句