AngularJS實(shí)現(xiàn)進(jìn)度條功能示例
本文實(shí)例講述了AngularJS實(shí)現(xiàn)進(jìn)度條功能的方法。分享給大家供大家參考,具體如下:
一、功能描述:
① 通過(guò)select標(biāo)簽,可以為進(jìn)度條選擇不同的樣式(顏色)
② 進(jìn)度條的進(jìn)度通過(guò)文本框里面的值改變(也可以快捷的選擇幾個(gè)特定的值)
③ 通過(guò)checkbox按鈕,控制進(jìn)度條上的文字是否顯示
二、代碼實(shí)現(xiàn):
<!DOCTYPE html>
<html lang="en" ng-app='app'>
<head>
<meta charset="UTF-8">
<title>進(jìn)度條</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>進(jìn)度:
<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預(yù)覽:

三、知識(shí)點(diǎn)分析
1、ng-class
ngclass實(shí)現(xiàn)有以下三種方式:
(1) 字符串形式:如果表達(dá)式求值為字符串,則字符串應(yīng)為一個(gè)或多個(gè)空格分隔的類名。
<div ng-class="'red'"></div>
說(shuō)明:字符串形式,每次只能綁定一個(gè)類名
(2) 數(shù)組形式:如果表達(dá)式求值為數(shù)組,則數(shù)組的每個(gè)元素應(yīng)為一個(gè)字符串,該字符串是一個(gè)或多個(gè)空格分隔的類名。如下:
<div ng-class="['Bar',vm.style]" ng-style="{width:vm.progress+'%'}">
<div ng-if='vm.text'>{{vm.progress}}%</div>
</div>
說(shuō)明:數(shù)組中可以存放一個(gè)變量,但是字符串形式只能存放常量
(3) 對(duì)象:如果表達(dá)式計(jì)算為對(duì)象,則對(duì)于具有真值的對(duì)象的每個(gè)鍵值對(duì),相應(yīng)的鍵用作類名。
<div ng-class {'selected': isSelected, 'car': isCar}">
說(shuō)明:當(dāng) isSelected = true 則增加selected class,當(dāng)isCar=true,則增加car class,
2、ng-style
ng-style的屬性值是一個(gè)對(duì)象,對(duì)象里的內(nèi)容是以key->value的形式展現(xiàn),key是屬性,value是值,如下:
<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 指令用于在表達(dá)式為 false 時(shí),移除指定html元素,當(dāng)表達(dá)式為true時(shí),則添加移除的html元素,并顯示,如下:
<div ng-if='vm.text'>{{vm.progress}}%</div>
說(shuō)明:當(dāng)vm.text為真時(shí)顯示視圖里面的內(nèi)容,否則移除
4、ng-model
ng-model 指令綁定了 HTML 表單元素到 scope 變量中,如下:
<select ng-model='vm.style'> <option value="red">red</option> <option value="green">green</option> <option value="blue">blue</option> </select>
說(shuō)明:在select標(biāo)簽中,ng-model的值為所選擇的option的value值
<input type="checkbox" ng-model='vm.text'>
說(shuō)明:在checkbox中,ng-model的值為true或者false
更多關(guān)于AngularJS相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《AngularJS指令操作技巧總結(jié)》、《AngularJS入門與進(jìn)階教程》及《AngularJS MVC架構(gòu)總結(jié)》
希望本文所述對(duì)大家AngularJS程序設(shè)計(jì)有所幫助。
相關(guān)文章
angular directive的簡(jiǎn)單使用總結(jié)
directive(指令)是angular的一個(gè)非常強(qiáng)大又有用的功能,它相當(dāng)于實(shí)現(xiàn)了組件化的概念,我們可以通過(guò)它公共地自定義DOM元素或CLASS類或ATTR屬性,并且在這基礎(chǔ)上進(jìn)行操作scope、綁定事件等等2017-05-05
Angular.js如何從PHP讀取后臺(tái)數(shù)據(jù)
這篇文章主要為大家簡(jiǎn)單介紹了Angular.js如何從PHP讀取后臺(tái)數(shù)據(jù),本文將Angular和PHP相結(jié)合,從后臺(tái)讀取數(shù)據(jù),感興趣的小伙伴們可以參考一下2016-03-03
AngularJS實(shí)現(xiàn)的鼠標(biāo)拖動(dòng)畫(huà)矩形框示例【可兼容IE8】
這篇文章主要介紹了AngularJS實(shí)現(xiàn)的鼠標(biāo)拖動(dòng)畫(huà)矩形框,涉及基于AngularJS的事件響應(yīng)及頁(yè)面元素屬性動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-05-05
使用AngularJS對(duì)路由進(jìn)行安全性處理的方法
這篇文章主要介紹了使用AngularJS對(duì)路由進(jìn)行安全性處理的方法,AngularJS是一款高人氣的JavaScript庫(kù),需要的朋友可以參考下2015-06-06
angular+webpack2實(shí)戰(zhàn)例子
本篇文章主要介紹了angular+webpack2實(shí)戰(zhàn)例子,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05
angular inputNumber指令輸入框只能輸入數(shù)字的實(shí)現(xiàn)
這篇文章主要介紹了angular inputNumber指令輸入框只能輸入數(shù)字的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12
angular1.x ui-route傳參的三種寫法小結(jié)
今天小編就為大家分享一篇angular1.x ui-route傳參的三種寫法小結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08

