- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
将 ngIf
优先级 (600) 设置为高于 {{ }}
(100) 的原因是什么?难道它不应该有较低的优先级来允许ng-if
属性值中的{{ }}
吗?
我想在 $scope
变量中有一个条件:
Controller :
app.controller('MainCtrl', function($scope, $http, $parse) {
$scope.hide = "check === 'hidden'";
$scope.parsecond = function (cond) {
return $parse(cond)($scope);
};
});
模板:
<body ng-controller="MainCtrl">
<div ng-if="!{{hide}}">funky ng-if div</div>
<div ng-hide="{{hide}}">ng-hide div</div>
<div ng-if="!parsecond(hide)">ng-if div</div>
<input type="input" ng-model="check" />
</body>
ng-hide
工作正常,因为它解析 hide 变量的内容并返回“check === 'hidden'”,然后由 ng-hide
对其进行评估指令。
但是 ng-if
尝试在 interpolate 有机会解析字符串之前评估 {{hide}}
,因此 ng-if
抛出异常。
我发现的唯一解决方案是调用一个函数,该函数基本上完成插值指令的工作并返回解析的内容。
Plnkr 显示问题:link
编辑:
阅读文档后,我找到了更好的方法,无需在 $scope
上使用自定义方法,因为 angularjs 已经有一个方法可以根据当前的 $ 解析变量范围
($eval
)。
所以我的解决方案是:
<body ng-controller="MainCtrl">
<div ng-if="!$eval(hide)">funky ng-if div</div>
<div ng-hide="{{hide}}">ng-hide div</div>
<div ng-if="!parsecond(hide)">ng-if div</div>
<input type="input" ng-model="check" />
</body>
更新了 plnkr:link
尽管这仍然不能解释为什么 ngIf 具有更高的优先级。
编辑2:
只是为了让人们明白这是不一样的:
例如:
Controller :
$scope.value = "hi";
$scope.condition = "value === 'bye'";
HTML:
<div ng-hide="condition"></div> <!--This will be evaluated to true since !!"value ==='bye'" = true. -->
<div ng-hide="{{condition}}"></div> <!--This will be evaluated to false since value !== 'bye' = false -->
<div ng-if="condition"></div> <!--This will be evaluated to true since !!"value === 'bye'" = true. -->
<div ng-if="{{condition}}"></div> <!--This will give an exception since ngIf directive ran before interpolation directive in the $compile step. -->
<div ng-if="$eval(condition)"></div> <!--This will be evaluated to false since value !== 'bye' = false. -->
我的结论是,如果您希望指令在字符串中而不是在作用域的属性中评估/设置监视,则使用 $parse
更安全。尽管我确实可以将 {{ }}
用于 ng-hide
/ng-show
或任何优先级低于 100 的指令但我猜它不安全,因为我依赖于编译顺序,并且不能 100% 清楚它在未来的补丁中不会改变。
最佳答案
ng-if
期望其值是一个 Angular 表达式 - under the hood它只是利用 $scope.$watch
。因此,如果您想条件包括 ng-if
的内容在范围内定义的某个变量上(比方说: scope.hide
),您可以输入 ng-if="hide"
在你的标记中。这里没有双花括号。
现在回到你的问题:确实是 ng-if
优先级为600
,但是 $interpolate
是 Angular 的服务 - 不是指令。因此$interpolate
没有定义优先级。你从哪里得到的100
来自?
您始终可以条件包括 ng-if
的内容在某些功能上(比如说 scope.conditionFn
),输入您的标记: ng-if="conditionFn()"
.
我更新了您的PLNKR使其发挥作用。 ng-if
之间的不一致和ng-hide
在你的plunker中与$compile
中发生的插值优先级无关.
看来你是对的,插值顺序在这里发挥了作用,但是......我真的没有看到任何在 Angular 表达式内部插值的好理由。原因ng-if
具有相对较高优先级的是它从 DOM 中删除/添加嵌入的内容,而 ng-hide
仅显示/隐藏嵌入的内容。我认为一个指令似乎起作用而另一个指令不起作用,这纯粹是巧合。 但是如果你不使用不必要的、多余的技巧,两者都会按预期工作,正如我的笨蛋所展示的那样。
关于angularjs - 为什么 ngIf 的优先级高于 {{ }} (插值)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23265948/
这个问题是关于理解为什么一种技术比另一种更好。在 Angular 4/5 中,在模板中,您可以通过执行以下操作来实现相同的目的: 1) *ngIf-else 语法 content here
我的 *ngIf 在一个特定变量 isAdmin 上遇到了一个奇怪的问题(这应该允许我在 userList 中显示用户列表)。我不确定为什么它的行为与同一组件中的所有其他 *ngIf 语句不同。 这是
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 5 年前。 Improve
我有一个自定义选项卡实现,其中我使用一些 ngIf 指令显示选项卡内容,如下所示: 选项卡有自己的形式,一些内容应该只初始化一次,不能再初始化。在我当前的实现中,每次我更改条件然后更改选项卡时,组
我的问题涉及 *ngif 指令,一次 *ngif=true 我希望在我的“ModClass”指令执行其操作之前首先呈现 html 内容。 我尝试实现 ngOnInit 和 ngViewInit 但没有
基本上,我有一个带有 *ngIf 条件的 div,但我在这个 div 中也有一个 img。这是一个登录页面,我想为不同类型的用户显示不同的登录页面。这就是我使用 ngIf 的原因。但是,直到我单击用户
我正在使用 Angular 6。 我有一个如下所示的 html。 此处,showMenus 默认为 false,并在单击同一页面中的按钮时将其设置为 true。 现在,我试图在将 show
演示: https://stackblitz.com/angular/mxoemeygmlk?file=app%2Ftable-http-example.ts 解决这个 Angular 误差的最佳解决
我正在使用 AngularDart,我需要根据 bool 值 registerDisplay 显示和隐藏组件。尝试使用 *ngIf ,但抛出错误。以下是 html。 app_component.htm
在一个组件中,我有一个与此类似的源代码: {{row.job_id}} Job ID Not available 我想在单个 ng-template 中使用
直接来自 angular.io 的示例对我不起作用: {{show ? 'hide' : 'show'}} show = {{show}} Text to show Alternate text w
我的观察是否正确,即使 *ngIf 宿主元素不在 DOM 中,它也在内存/堆中。因此它正在创建宿主元素但不将其附加到 DOM。 我在上面是因为我有一个巨大的列表。每个列表元素中都有一些 *ngIfs。
我有一段这样的代码 ng-show="!edit{{id}} && imageUrl" 但这似乎行不通。在哪里 ng-show="!edit1 && imageUrl" 有效。语法有问题吗?? 实际的
所以我试图更好地理解 Angulars ChangeDetection 并无意中遇到了一个问题: https://plnkr.co/edit/M8d6FhmDhGWIvSWNVpPm?p=previe
以下是一个 HTML 代码片段,其中 ngIf 检查 forceAngle 是否为真,默认情况下 forceAngle 为假。单击按钮后,我将调用 ForceAngles() 函数并将 forceAn
我有一个从多个地方调用的登录组件,并有一个输入将其显示为模态组件或只是普通组件。 登录组件: declare var jQuery: any; @Component({ selector: '
我正在使用 new Angular local variable assignment feature在 ngIf 下的子元素中引用异步管道的结果: 1"> There's more
我有一个 observable,我想在 ngIf 中创建一个变量,并且仅在值为 null 时返回 false(该 observable 返回一个数字) 我需要明确检查 null 因为我的 observ
我有一个组件 我只想显示是否设置了其属性之一。所以我想在做这样的事情: ... 事情是组件是在 HTML DOM 中创建的。所以,为了避免它的创建,我的假设是我应该把 * ngIf 在
当在 *ngIf 中使用 AsyncPipe 时,如果连接到 AsyncPipe 的 Observable 推送其*ngIf 变为真之前的值,从 AsyncPipe 返回的值将不正确。 例如,假设我有
我是一名优秀的程序员,十分优秀!