码迷,mamicode.com
首页 > Web开发 > 详细

AngularJS 过滤器

时间:2016-07-08 17:59:25      阅读:229      评论:0      收藏:0      [点我收藏+]

标签:

过滤器可以使用一个管道字符|)添加到表达式指令中。

AngularJS 过滤器

AngularJS 过滤器可用于转换数据:

过滤器描述
currency 格式化数字为货币格式。
filter 从数组项中选择一个子集。
lowercase 格式化字符串为小写。
orderBy 根据某个表达式排列数组。
uppercase 格式化字符串为大写。

向表达式中添加过滤器

过滤器可以通过一个管道字符(|)和一个过滤器添加到表达式中。

uppercase 过滤器将字符串格式化为大写:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>
    <div ng-app="myApp" ng-controller="personCtrl">
        <p>
            姓名为 {{ lastName | uppercase }}</p>
    </div>
    <script src="personController.js"></script>
</body>
</html>

personController.js:

var app = angular.module(‘myApp‘, []);
app.controller(‘personCtrl‘, function ($scope) {
    $scope.firstName = "John";
    $scope.lastName = "Doe";
    $scope.fullName = function () {
        return $scope.firstName + " " + $scope.lastName;
    }
});

lowercase 过滤器将字符串格式化为小写。

currency 过滤器将数字格式化为货币格式:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>
    <div ng-app="myApp" ng-controller="costCtrl">
        数量:
        <input type="number" ng-model="quantity">
        价格:
        <input type="number" ng-model="price">
        <p>
            总价 = {{ (quantity * price) | currency }}</p>
    </div>
    <script>
        var app = angular.module(myApp, []);
        app.controller(costCtrl, function ($scope) {
            $scope.quantity = 1;
            $scope.price = 9.99;
        });
    </script>
</body>
</html>

技术分享

向指令添加过滤器

过滤器可以通过一个管道字符(|)和一个过滤器添加到指令中。

orderBy 过滤器根据表达式排列数组:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>
    <div ng-app="myApp" ng-controller="namesCtrl">
        <p>
            循环对象:</p>
        <ul>
            <li ng-repeat="x in names | orderBy:‘country‘">{{ x.name + ‘, ‘ + x.country }} </li>
        </ul>
    </div>
    <script src="namesController.js"></script>
</body>
</html>

namesController.js

angular.module(‘myApp‘, []).controller(‘namesCtrl‘, function ($scope) {
    $scope.names = [
        { name: ‘Jani‘, country: ‘Norway‘ },
        { name: ‘Hege‘, country: ‘Sweden‘ },
        { name: ‘Kai‘, country: ‘Denmark‘ }
    ];
}); 

过滤输入

输入过滤器可以通过一个管道字符(|)和一个过滤器添加到指令中,该过滤器后跟一个冒号和一个模型名称。

filter 过滤器从数组中选择一个子集:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>
    <div ng-app="myApp" ng-controller="namesCtrl">
        <p>
            输入过滤:</p>
        <p>
            <input type="text" ng-model="test"></p>
        <ul>
            <li ng-repeat="x in names | filter:test | orderBy:‘country‘">{{ (x.name | uppercase)
                + ‘, ‘ + x.country }} </li>
        </ul>
    </div>
    <script src="namesController.js"></script>
</body>
</html>

技术分享

技术分享

AngularJS 过滤器

标签:

原文地址:http://www.cnblogs.com/chrisghb8812/p/5654152.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!