這篇文章主要介紹了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=https://www.cnblogs.com/P-Z-1/p/'../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=https://www.cnblogs.com/P-Z-1/p/"red">red</option>
<option value=https://www.cnblogs.com/P-Z-1/p/"green">green</option>
<option value=https://www.cnblogs.com/P-Z-1/p/"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程式設計有所幫助,
原文:https://www.jb51.net/article/117920.htm
轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/58164.html
標籤:JavaScript
