Skip to content

样式选择器 ng-class/ng-style

作者:guo-zi-xin
更新于:9 个月前
字数统计:1.2k 字
阅读时长:4 分钟

ng-class

通过ng-class,我们可以对界面元素的css样式进行控制。下面,让我们通过示例来看看功能如何实现:

此示例来源于官网的 ngClass介绍界面 ,我进行了一些加工。

首先,我们先创建一个style.css文件。

css
/* 删除线 */
.strike {
    text-decoration: line-through;
}

/* 粗体 */
.bold {
    font-weight: bold;
}

/* 红色 */
.red {
    color: red;
}

/* 错误 */
.has-error {
    color: red;
    background-color: yellow;
}

/* 橙色 */
.orange {
    color: orange;
}

修改FirstCtrl为如下代码:

javascript
//app.js
App.controller("FirstCtrl", function ($scope) {
    $scope.data = {
        deleted:false,
        important:false,
        error:false
    };
});

并在index.html<head>部分将css文件引入,并加入对应的代码。全部代码如下:

html
<!DOCTYPE html>
<html lang="zh" ng-app="App">
<head>
    <meta charset="UTF-8">
    <title>{{"学习AngularJS 1.x"}}</title>

    <!-- 此处引入style.css样式文件-->
    <link type="text/css" rel="stylesheet" href="css/style.css">

</head>
<body>
<div ng-controller="FirstCtrl">

    <!-- 此处放置了ng-class,并设定了每个样式激活时的条件(对应下方3个复选框)-->
    <p ng-class="{strike: data.deleted, bold: data.important, 'has-error': data.error}">示例文字</p>
    <input type="checkbox" ng-model="data.deleted">
        选中后上方文字将加上删除线(style中加上strike类) <br>
    <input type="checkbox" ng-model="data.important">
        选中后上方文字将变化为粗体(style中加上bold类) <br>
    <input type="checkbox" ng-model="data.error">
        选中后上方文字将变红,背景变黄(style中加上has-error类)
</div>

<script type="text/javascript" src="components/angular/angular.js"></script>
<script type="text/javascript" src="js/app.js"></script>
</body>
</html>

运行效果:

未选中时效果

图4-11 ngClass运行效果

选中第一个的效果

图4-12 ngClass运行效果

选中第二个的效果

图4-13 ngClass运行效果

选中第三个的效果

图4-14 ngClass运行效果

全部选中的效果

图4-15 ngClass运行效果

动态化的样式输入

在上方的示例中,我们是针对提前设定好的样式进行是否生效的判断。除了这种使用方式,ng-class还支持直接传入字符串的方式进行样式调整。

比如如下示例:

javascript
App.controller("FirstCtrl", function ($scope) {
    $scope.data = {
        style: ""
    };
});
html
<div ng-controller="FirstCtrl">
    <p ng-class="data.style">直接使用字符串作为样式</p>
    <input type="text" ng-model="data.style">
</div>

运行效果

图4-16 ngClass运行效果(使用文本作为样式)

结合两种模式的应用示例

这两种模式也可以结合使用,示例如下:

html
<p ng-class="[data.style, {orange: warning}]">同时应用两种样式</p>

此示例可举一反三,比如加入多个文本输入(对应多个来源),以及多个设定好的样式开关。

此示例就不进行具体的运行效果展示了,请读者自行测试效果。

CSS动画效果应用

我们先在_style.css_中加入css的动画效果代码:

css
.base-class {
    transition:all cubic-bezier(0.250, 0.460, 0.450, 0.940) 0.5s;
}

.base-class.animate {
    color: red;
    font-size:3em;
}

修改HTML代码如下:

html
<div ng-controller="FirstCtrl">
    <input type="button" value="开始动画" ng-click="data.style='animate'">
    <br>
    <input type="button" value="恢复原始" ng-click="data.style=''">
    <br>
    <span class="base-class" ng-class="data.style">示例文本</span>
</div>

运行之后,点击上面的按钮,则文字放大变红。点击第二个按钮,则文本变回原来的样子。

由于动画效果无法通过截图表示,还请读者自行测试。

ng-style

ng-style提供的功能比ng-class要少一些,只支持样式的传入。我们可以使用以下两种模式:

html
<span ng-style="{'background-color':data.colorInput}">示例文本</span>
//colorInput为$scope中的对象,传入文本即可

<span ng-style="data.styleText">示例文本</span>
//styleText为样式为 '{'color':red}'类型的文本

通过样式传入,我们可以直接向元素传入对应的样式,实现样式动态化的效果。

一个比较主要的用途是向元素传入动态的背景图片,例子如下(以下两个示例来自于

):

html
data-ng-style="{'background-image':'url(img/products/{{product.img}})'}"

也可以传入一个函数(主要用于解决IE11中背景图片不显示的问题):

html
<div ng-style="getBackgroundStyle(imagepath)"></div>

<script type="text/javascript">
    //代码放置在ng-controller中
    $scope.getBackgroundStyle = function (imagepath) {
        return {
            'background-image': 'url(' + imagepath + ')'
        }
    }
</script>

下面,我们通过官网的

来看看如何传入文本:

html
<input type="button" value="设置字体颜色为红色" ng-click="data.myStyle={color:'red'}">
<input type="button" value="设置背景颜色" ng-click="data.myStyle={'background-color':'blue'}">
<input type="button" value="清除样式" ng-click="data.myStyle={}">
<br>
<span ng-style="data.myStyle">示例文本</span>
<pre>当前样式为{{data.myStyle}}</pre>

运行效果为:

图4-17 ng-style运行效果

在下一节中,我们还将看到约束为只设置背景颜色的示例。

人生没有捷径,就像到二仙桥必须要走成华大道。