aboutsummaryrefslogtreecommitdiffstats
path: root/docs/angular.filter.ngdoc
blob: 5d4f5940807cc5a56f07c3d9630e23d3654ebdcb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
@workInProgress
@ngdoc overview
@name angular.filter
@namespace Namespace for all filters.
@description
# Overview
Filters are a standard way to format your data for display to the user. For example, you
might have the number 1234.5678 and would like to display it as US currency: $1,234.57.
Filters allow you to do just that. In addition to transforming the data, filters also modify
the DOM. This allows the filters to for example apply css styles to the filtered output if
certain conditions were met.


# Standard Filters

The Angular framework provides a standard set of filters for common operations, including:
{@link angular.filter.currency currency}, {@link angular.filter.json json},
{@link angular.filter.number number}, and {@link angular.filter.html html}. You can also add
your own filters.


# Syntax

Filters can be part of any {@link angular.scope} evaluation but are typically used with
{{bindings}}. Filters typically transform the data to a new data type, formating the data in
the process. Filters can be chained and take optional arguments. Here are few examples:

* No filter: {{1234.5678}} => 1234.5678
* Number filter: {{1234.5678|number}} => 1,234.57. Notice the , and rounding to two
  significant digits.
* Filter with arguments: {{1234.5678|number:5}} => 1,234.56780. Filters can take optional
  arguments, separated by colons in a binding. To number, the argument 5 requests 5 digits
  to the right of the decimal point.


# Writing your own Filters

Writing your own filter is very easy: just define a JavaScript function on `angular.filter`.
The framework passes in the input value as the first argument to your function. Any filter
arguments are passed in as additional function arguments.

You can use these variables in the function:

* `this`  The current scope.
* `this.$element`  The DOM element containing the binding. This allows the filter to manipulate
  the DOM in addition to transforming the input.


@example
 The following example filter reverses a text string. In addition, it conditionally makes the
 text upper-case (to demonstrate optional arguments) and assigns color (to demonstrate DOM
 modification).

<doc:example>
 <doc:source>
   <script type="text/javascript">
     angular.filter('reverse', function(input, uppercase, color) {
       var out = "";
       for (var i = 0; i < input.length; i++) {
         out = input.charAt(i) + out;
       }
       if (uppercase) {
         out = out.toUpperCase();
       }
       if (color) {
         this.$element.css('color', color);
       }
       return out;
     });
   </script>

   <input name="text" type="text" value="hello" /><br>
   No filter: {{text}}<br>
   Reverse: {{text|reverse}}<br>
   Reverse + uppercase: {{text|reverse:true}}<br>
   Reverse + uppercase + blue:  {{text|reverse:true:"blue"}}
 </doc:source>
 <doc:scenario>
  it('should reverse text', function(){
    expect(binding('text|reverse')).toEqual('olleh');
    input('text').enter('ABC');
    expect(binding('text|reverse')).toEqual('CBA');
  });
 </doc:scenario>
</doc:example>