【发布时间】:2016-08-30 16:37:08
【问题描述】:
我有两个角度分量:app-menuitem 和 app-menu。 app-menu 有一个作为子项的 app-menuitem 列表,但没有嵌入。
应用菜单项
angular.module('app')
.component('appMenuitem', {
transclude: false,
controller: menuitemController,
require: {
parent: '^?app-menu'
},
bindings: {
...
groupradio: '@',
isactive: '<', // bind to active (just init)
...
},
templateUrl: 'angular/components/simple/menuitem/menuitem.html'
});
function menuitemController($rootScope, $scope, $element, $attrs) {
var ctrl = this;
//Default values
ctrl.$onInit = function () {
if(ctrl.isactive){
ctrl.active = true;
}else{
ctrl.active = false;
}
ctrl.selectRadioItem = function(){
if(!ctrl.active){
var currentMenu = this.parent.items.menu;
var levelMenu = this.parent.items.level;
for(var i = 0; i < currentMenu.length; i++){
var currentMenuItem = currentMenu[i];
if(currentMenuItem.groupradio === ctrl.groupradio){
if(currentMenuItem.index === ctrl.index){
currentMenuItem.isactive = true;
}else{
currentMenuItem.isactive = false;
}
currentMenu[i] = currentMenuItem;
}
}
this.parent.items.menu = currentMenu;
console.dir(this.parent); //<-- updates are visible but the html did not change.
}
...
正如您在这段代码末尾看到的那样,我设法从这个子组件app-menuitem 修改了父组件 app-menu,但在这种情况下,HTML 再也不会编译了。有人有想法吗?
【问题讨论】:
-
为什么不使用数据绑定?
-
我正在使用“绑定”属性...你是什么意思?
-
您介意发布菜单项的 html 吗?
标签: angularjs angular compilation components parent-child