做网站应该用什么语言来开发,连接wordpress,足球联赛排名,室内设计主要是干什么的Angular过滤器 在HTML中的模板绑定符号{{ }}内通过|符号来调用过滤器。例如#xff0c;假设我们希望将字符串转换成大写#xff0c;可以对字符串中的每个字符都单独进行转换操作#xff0c;也可以使用过滤器#xff1a; {{ name | uppercase }} //大写 在JavaScript代码…Angular过滤器 在HTML中的模板绑定符号{{ }}内通过|符号来调用过滤器。例如假设我们希望将字符串转换成大写可以对字符串中的每个字符都单独进行转换操作也可以使用过滤器 {{ name | uppercase }} //大写 在JavaScript代码中可以通过$filter来调用过滤器。例如在JavaScript代码中使用lowercase过滤器 app.controller(DemoController, [$scope, $filter,
function($scope, $filter) {
$scope.name $filter(lowercase)(Ari); //小写ari
}]); 以HTML的形式使用过滤器时如果需要传递参数给过滤器只要在过滤器名字后面加冒号即可。如果有多个参数可以在每个参数后面都加入冒号。例如数值过滤器可以限制小数点后的位数在过滤器后写上:2可以将2作为参数传给过滤器!-- 显示123.46 -- {{ 123.456789 | number:2 }} 可以用 | 符号作为分割符来同时使用多个过滤器。 AngularJS提供的内置过滤器。 1. currencycurrecy过滤器可以将一个数值格式化为货币格式。用{{ 123 | currency }}来将123转化成货币格式。currecy过滤器允许我们自己设置货币符号。默认情况下会采用客户端所处区域的货币符号但是也可以自定义货币符号。2. datedate过滤器可以将日期格式化成需要的格式。AngularJS中内置了几种日期格式如果没有指定使用任何格式默认会采用mediumDate格式下面的例子中展示了这个格式。下面是内置的支持本地化的日期格式 {{ today | date:medium }} !-- Aug 09, 2013 12:09:02 PM --
{{ today | date:short }} !-- 8/9/1312:09PM --
{{ today | date:fullDate }} !-- Thursday, August 09, 2013 --
{{ today | date:longDate }} !-- August 09, 2013 --
{{ today | date:mediumDate }}!-- Aug 09, 2013 --
{{ today | date:shortDate }} !-- 8/9/13 --
{{ today | date:mediumTime }}!-- 12:09:02 PM --
{{ today | date:shortTime }} !-- 12:09 PM --{{ today | date:medium }} !-- Aug 09, 2013 12:09:02 PM --
{{ today | date:short }} !-- 8/9/1312:09PM --
{{ today | date:fullDate }} !-- Thursday, August 09, 2013 --
{{ today | date:longDate }} !-- August 09, 2013 --
{{ today | date:mediumDate }}!-- Aug 09, 2013 --
{{ today | date:shortDate }} !-- 8/9/13 --
{{ today | date:mediumTime }}!-- 12:09:02 PM --
{{ today | date:shortTime }} !-- 12:09 PM -- 年份格式化四位年份{{ today | date:yyyy }} !-- 2013 --两位年份{{ today | date:yy }} !-- 13 --一位年份{{ today | date:y }} !-- 2013 -- 月份格式化英文月份{{ today | date:MMMM }} !-- August --英文月份简写{{ today | date:MMM }} !-- Aug --数字月份{{ today |date:MM }} !-- 08 --一年中的第几个月份{{ today |date:M }} !-- 8 -- 日期格式化数字日期{{ today|date:dd }} !-- 09 --一个月中的第几天{{ today | date:d }} !-- 9 --英文星期{{ today | date:EEEE }} !-- Thursday --英文星期简写{{ today | date:EEE }} !-- Thu -- 小时格式化24小时制数字小时{{today|date:HH}} !--00--一天中的第几个小时{{today|date:H}} !--0--12小时制数字小时{{today|date:hh}} !--12--上午或下午的第几个小时{{today|date:h}} !--12-- 分钟格式化数字分钟数{{ today | date:mm }} !-- 09 --一个小时中的第几分钟{{ today | date:m }} !-- 9 -- 秒数格式化数字秒数{{ today | date:ss }} !-- 02 --一分钟内的第几秒{{ today | date:s }} !-- 2 --毫秒数{{ today | date:.sss }} !-- .995 -- 字符格式化上下午标识{{ today | date:a }} !-- AM --四位时区标识{{ today | date:Z }} !--- 0700 -- 下面是一些自定义日期格式的示例{{ today | date:MMMd, y }} !-- Aug9, 2013 --{{ today | date:EEEE, d, M }} !-- Thursday, 9, 8--{{ today | date:hh:mm:ss.sss }} !-- 12:09:02.995 --3. filterfilter过滤器可以从给定数组中选择一个子集并将其生成一个新数组返回。这个过滤器通 常用来过滤需要进行展示的元素。例如在做客户端搜索时可以从一个数组中立刻过滤出所需的结果。这个过滤器的第一个参数可以是字符串、对象或是一个用来从数组中选择元素的函数。下面分情况介绍传入不同类型的参数。 字符串返回所有包含这个字符串的元素。如果我们想返回不包含该字符串的元素在参数前加!符号。 对象AngularJS会将待过滤对象的属性同这个对象中的同名属性进行比较如果属性值是字符串就会判断是否包含该字符串。如果我们希望对全部属性都进行对比可以将$当作键名。 函数对每个元素都执行这个函数返回非假值的元素会出现在新的数组中并返回。例如用下面的过滤器可以选择所有包含字母e的单词 {{ [Ari,Lerner,Likes,To,Eat,Pizza] | filter:e }}
!-- [Lerner,Likes,Eat] -- 如果要过滤对象可以使用上面提到的对象过滤器。例如如果有一个由people对象组成的数组每个对象都含有他们最喜欢吃的食物的列表那么可以用下面的形式进行过滤 {{ [{
name: Ari,
City: San Francisco,
favorite food: Pizza
},{
name: Nate,
City: San Francisco,
favorite food: indian food
}] | filter:{favorite food: Pizza} }}
!-- [{name:Ari,City:SanFrancisco,favoritefood:Pizza}] -- 也可以用自定义函数进行过滤在这个例子中函数定义在$scope上 {{ [Ari,likes,to,travel] | filter:isCapitalized }}
!-- [Ari] -- isCapitalized函数的功能是根据首字母是否为大写返回true或false具体如下所示$scope.isCapitalized function(str) {return str[0] str[0].toUpperCase();};我们也可以给filter过滤器传入第二个参数用来指定预期值同实际值进行比较的方式。第二个参数可以是以下三种情况之一。 true用angular.equals(expected, actual)对两个值进行严格比较。 false进行区分大小写的子字符串比较。 函数运行这个函数如果返回真值就接受这个元素。4. jsonjson过滤器可以将一个JSON或JavaScript对象转换成字符串。这种转换对调试非常有帮助 {{ {name: Ari, City: SanFrancisco} | json }}
!--
{
name: Ari,
City: San Francisco
}
-- 5. limitTolimitTo过滤器会根据传入的参数生成一个新的数组或字符串新的数组或字符串的长度取决于传入的参数通过传入参数的正负值来控制从前面还是从后面开始截取。如果传入的长度值大于被操作数组或字符串的长度那么整个数组或字符串都会被返回。例如我们可以截取字符串的前三个字符 {{ San Francisco is very cloudy | limitTo:3 }}
!-- San -- 或最后的六个字符 {{ San Francisco is very cloudy | limitTo:-6 }}
!-- cloudy -- 对数组也可以进行同样的操作。返回数组的第一个元素 {{ [a,b,c,d,e,f] | limitTo:1 }}
!-- [a] -- 6. lowercase {{ 123456789 | number }}
!-- 1,234,567,890 --{{ 1.234567 | number:2 }}
!-- 1.23 -- lowercase过滤器将字符串转为小写。 {{ San Francisco is very cloudy | lowercase }}
!-- san francisco is very cloudy -- 7. numbernumber过滤器将数字格式化成文本。它的第二个参数是可选的用来控制小数点后截取的位数。如果传入了一个非数字字符会返会空字符串。 8. orderByorderBy过滤器可以用表达式对指定的数组进行排序。orderBy可以接受两个参数第一个是必需的第二个是可选的。第一个参数是用来确定数组排序方向的谓词。下面分情况讨论第一个参数的类型。 函数当第一个参数是函数时该函数会被当作待排序对象的getter方法。 字符串对这个字符串进行解析的结果将决定数组元素的排序方向。我们可以传入或-来强制进行升序或降序排列。 数组在排序表达式中使用数组元素作为谓词。对于与表达式结果并不严格相等的每个元素则使用第一个谓词。第二个参数用来控制排序的方向是否逆向。例如我们将下面的对象数组用name字段进行排序 {{ [{
name: Ari,
status: awake
},{
name: Q,
status: sleeping
},{
name: Nate,
status: awake
}] | orderBy:name }}
!--
[
{name:Ari,status:awake},
{name:Nate,status:awake},
{name:Q,status:sleeping}
]
-- 也可以对排序结果进行反转。例如通过将第二个参数设置为true可以将排序结果进行反转 {{ [{
name: Ari,
status: awake
},{
name: Q,
status: sleeping
},{
name: Nate,status: awake
}] | orderBy:name:true }}
!--
[
{name:Q,status:sleeping},
{name:Nate,status:awake},
{name:Ari,status:awake}
]
-- 9. uppercaseuppercase过滤器可以将字符串转换为大写形式 {{ San Francisco is very cloudy | uppercase }}
!-- SAN FRANCISCO IS VERY CLOUDY -- 自定义过滤器 创建自定义过滤器需要将它放到自己的模块中。 首先创建一个模块用以在应用中进行引用: angular.module(myApp.filters, [])
.filter(capitalize, function() {
return function(input) {};
}); 过滤器本质上是一个会把我们输入的内容当作参数传入进去的函数。上面这个例子中我们在调用过滤器时简单地把input当作字符串来处理。可以在这个函数中做一些错误检查 angular.module(myApp.filters, [])
.filter(capitalize, function() {
return function(input) {
// input是我们传入的字符串
if (input) {
return input[0].toUpperCase() input.slice(1); //把第一个字母转换成大写
}
}); 现在如果想将一个句子的首字母转换成大写形式可以用过滤器先将整个句子都转换成小写再把首字母转换成大写 !-- Ginger loves dog treats --
{{ ginger loves dog treats | lowercase | capitalize }} 表单验证 如果想要屏蔽浏览器对表单的默认验证行为可以在表单元素上添加novalidate标记。 下面看一下可以在input元素上使用的所有验证选项。1. 必填项验证某个表单输入是否已填写只要在输入字段元素上添加HTML5标记required即可 input typetext required / 2. 最小长度验证表单输入的文本长度是否大于某个最小值在输入字段上使用AngularJS指令ng-minleng {number}
input typetext ng-minlength5 / 3. 最大长度验证表单输入的文本长度是否小于或等于某个最大值在输入字段上使用AngularJS指令 ng-maxlength{number}
input typetext ng-maxlength20 / 4. 模式匹配使用ng-pattern/PATTERN/来确保输入能够匹配指定的正则表达式 input typetext ng-pattern[a-zA-Z] / 5. 电子邮件验证输入内容是否是电子邮件只要像下面这样将input的类型设置为email即可 input typeemail nameemail ng-modeluser.email / 6. 数字验证输入内容是否是数字将input的类型设置为number input typenumber nameage ng-modeluser.age / 7. URL验证输入内容是否是URL将input的类型设置为 url input typeurl namehomepage ng-modeluser.facebook_url / 8. 自定义验证 自定义变量在往后的博文中作详细介绍。 9. 在表单中控制变量 注意可以使用下面的格式访问这些属性。formName.inputFieldName.property 未修改的表单这是一个布尔属性用来判断用户是否修改了表单。如果未修改值为true如果修改过值为falseformName.inputFieldName.$pristine 修改过的表单只要用户修改过表单无论输入是否通过验证该值都返回trueformName.inputFieldName.$dirty 合法的表单这个布尔型的属性用来判断表单的内容是否合法。如果当前表单内容是合法的下面属性的值就是trueformName.inputFieldName.$valid 不合法的表单这个布尔属性用来判断表单的内容是否不合法。如果当前表单内容是不合法的下面属性的值为trueformName.inputFieldName.$invalid 错误这是AngularJS提供的另外一个非常有用的属性$error对象。它包含当前表单的所有验证内容以及它们是否合法的信息。用下面的语法访问这个属性formName.inputfieldName.$error 如果验证失败这个属性的值为true如果值为false说明输入字段的值通过了验证。10. 一些有用的CSS样式AngularJS处理表单时会根据表单当前的状态添加一些CSS类例如当前是合法的、未发变化的等等这些CSS类的命名和前面介绍的属性很相似。 它们包括.ng-pristine {}.ng-dirty {}.ng-valid {}.ng-invalid {}它们对应着表单输入字段的特定状态。当某个字段中的输入非法时.ng-invlid类会被添加到这个字段上。当前例子中的站点将对应的CSS样式设置为 input.ng-invalid {
border: 1px solid red;
}
input.ng-valid {
border: 1px solid green;
} $parsers当用户同控制器进行交互并且ngModelController中的$setViewValue()方法被调用时$parsers数组中的函数会以流水线的形式被逐个调用。第一个$parse被调用后执行结果会传递给第二个$parse以此类推。这些函数可以对输入值进行转换或者通过$setValidity()函数设置表单的合法性。使用$parsers数组是实现自定义验证的途径之一。例如假设我们想要确保输入值在某两个数值之间可以在$parsers数组中入栈一个新的函数这个函数会在验证链中被调用。每个$parser返回的值都会被传入下一个$parser中。当不希望数据模型发生更新时返回undefined。 angular.module(myApp)
.directive(oneToTen, function() {
return {
require: ?ngModel,
link: function(scope, ele, attrs, ngModel) {
if (!ngModel) return;
ngModel.$parsers.unshift(
function(viewValue) {
var i parseInt(viewValue);
if (i 0 i 10) {
ngModel.$setValidity(oneToTen, true);
return viewValue;
} else {
ngModel.$setValidity(oneToTen, false);
return undefined;
}});
}
};
}); $formatters当绑定的ngModel值发生了变化并经过$parsers数组中解析器的处理后这个值会被传递给$formatters流水线。同$parsers数组可以修改表单的合法性状态类似$formatters中的函数也可以修改并格式化这些值。比起单纯的验证目的这些函数更常用来处理视图中的可视变化。例如假设我们要对某个值进行格式化。通过$formatters数组可以在这个值上执行过滤器 angular.module(myApp)
.directive(oneToTen, function() {
return {
require: ?ngModel,
link: function(scope, ele, attrs, ngModel) {
if (!ngModel) return;
ngModel.$formatters.unshift(function(v) {
return $filter(number)(v);
});
}
};
}); 转载于:https://www.cnblogs.com/lymblog/p/7264256.html