edit
-
{{item.value}}
function ctrl($scope) {
'ngInject';
$scope.items = [
{
title: "item1",
value: "value1"
},{
title: "item2",
value: "value2"
},{
title: "item3",
value: "value3"
}
];
$scope.isEdit = false;
$scope.submitForm = function(){
$scope.isEdit = false;
}
}
页面组成是这样的,一部分是信息显示,一部分是信息编辑;正常情况下显示部分展示,编辑部分隐藏;当点击edit后显示部分隐藏,编辑部分展示。
问题:
ng-click="isEdit = !isEdit" 无效
为什么当点击了取消或提交按钮之后,页面没有发生任何变化呢,依旧是编辑部分展示?
pluker 展示请戳这里
Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
ngIf是有作用域的,你的点击事件是在ngIf内,跨作用域操作的是在ngIf外面的isEdit
两种解决方法
1.把ngIf换成ngShow
2.把isEdit写成vm.isEdit解决跨作用域的问题;或者用$rootScope把isEdit放在根作用域;