- A+
这篇文章主要介绍了AngularJS实现进度条功能,结合具体完整实例形式分析了AngularJS实现进度条功能的原理、相关知识点与注意事项,需要的朋友可以参考下
本文实例讲述了AngularJS实现进度条功能的方法。分享给大家供大家参考,具体如下:
一、功能描述:
① 通过select标签,可以为进度条选择不同的样式(颜色)
② 进度条的进度通过文本框里面的值改变(也可以快捷的选择几个特定的值)
③ 通过checkbox按钮,控制进度条上的文字是否显示
二、代码实现:
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
|
<!DOCTYPE html> <html lang= "en" ng-app= 'app' > <head> <meta charset= "UTF-8" > <title>进度条</title> <script src= '../js/angular.min.js' ></script> <style> .progress{ width:400px; border:1px solid #ccc; height: 28px; text-align: center; line-height: 28px; font-weight: bold; color: #fff; overflow: hidden; } .Bar{ width:50%; height: 28px; background: #5BC0DE; } .blue{ background: #5BC0DE; } .red{ background: #D9534F; } .green{ background: green; } </style> </head> <body ng-controller= 'progresscontro' > <div class= "progress" > <div ng-class= "['Bar',vm.style]" ng-style= "{width:vm.progress+'%'}" > <div ng- if = 'vm.text' >{{vm.progress}}%</div> </div> </div> </br> <label> 颜色: <select ng-model= 'vm.style' > <option value= "red" >red</option> <option value= "green" >green</option> <option value= "blue" >blue</option> </select> </label> </br></br> <label>进度: <input type= "number" ng-model= 'vm.progress' ng-change= "vm.myFunc()" > <button ng-click= 'vm.progress=0' >0%</button> <button ng-click= 'vm.progress=20' >20%</button> <button ng-click= 'vm.progress=40' >40%</button> <button ng-click= 'vm.progress=60' >60%</button> <button ng-click= 'vm.progress=80' >80%</button> </label> </br></br> <label> 是否显示文字: <input type= "checkbox" ng-model= 'vm.text' > </label> <script> var app=angular.module( 'app' ,[]); app.controller( 'progresscontro' , function ($scope){ var vm=$scope.vm={}; vm.style= 'blue' ; vm.progress=50; vm.text= true ; vm.myFunc= function (){ if (vm.progress>100){ vm.progress=100; } if (vm.progress<0){ vm.progress=0; } } }) </script> </body> </html> |
demo预览:
三、知识点分析
1、ng-class
ngclass实现有以下三种方式:
(1) 字符串形式:如果表达式求值为字符串,则字符串应为一个或多个空格分隔的类名。
1
|
< div ng-class = "'red'" ></ div > |
说明:字符串形式,每次只能绑定一个类名
(2) 数组形式:如果表达式求值为数组,则数组的每个元素应为一个字符串,该字符串是一个或多个空格分隔的类名。如下:
1
2
3
|
< div ng-class = "['Bar',vm.style]" ng-style = "{width:vm.progress+'%'}" > < div ng-if = 'vm.text' >{{vm.progress}}%</ div > </ div > |
说明:数组中可以存放一个变量,但是字符串形式只能存放常量
(3) 对象:如果表达式计算为对象,则对于具有真值的对象的每个键值对,相应的键用作类名。
1
|
< div ng-class {'selected': isSelected, 'car': isCar}"> |
说明:当 isSelected = true 则增加selected class,当isCar=true,则增加car class,
2、ng-style
ng-style的属性值是一个对象,对象里的内容是以key->value的形式展现,key是属性,value是值,如下:
1
2
3
|
< div ng-class = "['Bar',vm.style]" ng-style = "{width:vm.progress+'%'}" > < div ng-if = 'vm.text' >{{vm.progress}}%</ div > </ div > |
3、ng-if
ng-if 指令用于在表达式为 false 时,移除指定html元素,当表达式为true时,则添加移除的html元素,并显示,如下:
1
|
< div ng-if = 'vm.text' >{{vm.progress}}%</ div > |
说明:当vm.text为真时显示视图里面的内容,否则移除
4、ng-model
ng-model 指令绑定了 HTML 表单元素到 scope 变量中,如下:
1
2
3
4
5
|
< select ng-model = 'vm.style' > < option value = "red" >red</ option > < option value = "green" >green</ option > < option value = "blue" >blue</ option > </ select > |
说明:在select标签中,ng-model的值为所选择的option的value值
1
|
< input type = "checkbox" ng-model = 'vm.text' > |
希望本文所述对大家AngularJS程序设计有所帮助。