作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 ng-if
用于打开和关闭。
我只能将值设置为 true
显示 child ,但我无法将值设置回 false
.
这是我的代码:
var app = angular.module('plunker', []);
var array = [{'name':'one'}, {'name':'two'}, {'name':'three'}];
app.controller('MainCtrl', function($scope) {
$scope.names = array;
$scope.showChild = function ( obj ) {
obj.show = true;
}
$scope.closeChild = function ( n ) {
n.show = false;
}
});
<ul>
<li ng-repeat="n in names" ng-click="showChild(n)">
{{n.name}}
<h2 ng-if="n.show">
{{n.name | uppercase }}
</h2>
<span ng-click="closeChild(n)">
Close
</span>
</li>
</ul>
最佳答案
这就是事件冒泡(向上传播事件)的工作原理。
基本上这种情况发生父元素和子元素都有 click
事件绑定(bind)到他们。当您单击内部元素时,它首先调用它自己的单击事件,然后它调用父元素 click
通过冒泡该事件来事件。这就是您当前实现中的问题。因此,您需要通过调用 stopPropagation
来停止事件向上传播来自 closeChild
的事件的方法方法。要获取事件对象,您需要通过 $event
来自 ng-click
的对象方法可以是$event
.
网页
<li ng-repeat="n in names" ng-click="showChild(n)">
{{n.name }} {{n}}
<h2 ng-if="n.show">{{n.name | uppercase }}</h2>
<span ng-click="closeChild($event, n)">Close</span>
</li>
$scope.closeChild = function(event, n) {
event.stopPropagation();
n.show = false;
}
关于javascript - Angular 我只能在 'true` 上设置 `ng-if` 但我不能设置 `false',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34392128/
有一条(相对)众所周知的 Perl 公理:“只有 Perl 可以解析 Perl”。我想知道 Perl 6 是否仍然如此? 扩大讨论...考虑到 PyPy 最近的更新,我想到了这个问题。 Perl 独特
这是设置。在上一个问题中,我发现我可以通过子组件中的状态传递对象属性,然后使用 componentDidUpdate 获取该对象属性。在这种情况下,状态和属性都称为到达。 这是基本代码... expo
我运行的是 10.5.2 社区版。我已经标记了 源/主要/资源 作为源目录。我可以右键单击并“编译”某些文件,据我所知,这意味着 IDE 将文件复制到与发送类文件的“com.mydomain.pack
我是一名优秀的程序员,十分优秀!