首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >你能用AngularJS进行条件格式化吗?

你能用AngularJS进行条件格式化吗?
EN

Stack Overflow用户
提问于 2014-04-18 18:52:12
回答 2查看 4.3K关注 0票数 3

我有一个包含来自我的控制器的值的元素:

代码语言:javascript
复制
<span>[[myvalue]]</span>

我会根据值改变背景色。例如,值1-5应该是红色的,6-10应该是绿色的。

代码语言:javascript
复制
<span style='background-color: #green'>9</span>
<span style='background-color: #red'>1</span>

要做到这一点,最简单的方法是什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-04-18 18:58:55

正如tymeJV在ngStyle中提到的,您也可以使用ngClass

代码语言:javascript
复制
<span ng-class="{'myClass' : (myValue < 9)}">{{myValue}}</span>

此外,为了促进一些单元测试,我还建议将逻辑放入一个函数中,这样您就可以轻松地进行测试,因为它还使标记更容易阅读。

标记

代码语言:javascript
复制
<span ng-class="{'myClass' : isSpecial(myValue)}">{{myValue}}</span>

控制器

代码语言:javascript
复制
$scope.isSpecial = function(value){ return myValue < 9};

当然,我的例子和你的例子是有点人为的,但可以帮助使事情更容易维护以后。

票数 5
EN

Stack Overflow用户

发布于 2014-04-18 19:46:16

下面是一个使用ngStyle的示例

代码语言:javascript
复制
<span  ng-style="myStyle(myValue)"> {{myValue}} </span>

主计长:

代码语言:javascript
复制
$scope.myStyle= function(value){
    return parseInt(value) > 5 ? {color: 'green'} : {color: 'red'}
}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23160355

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档