本文实例讲述了AngularJS实现进度条功能的方法。分享给大家供大家参考,具体如下:
一、功能描述:
① 通过select标签,可以为进度条选择不同的样式(颜色)
② 进度条的进度通过文本框里面的值改变(也可以快捷的选择几个特定的值)
③ 通过checkbox按钮,控制进度条上的文字是否显示
二、代码实现:
<!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) 字符串形式:如果表达式求值为字符串,则字符串应为一个或多个空格分隔的类名。
<div ng-class="'red'"></div>
说明:字符串形式,每次只能绑定一个类名
(2) 数组形式:如果表达式求值为数组,则数组的每个元素应为一个字符串,该字符串是一个或多个空格分隔的类名。如下:
<div ng-class="['Bar',vm.style]" ng-style="{width:vm.progress+'%'}"> <div ng-if='vm.text'>{{vm.progress}}%</div> </div>
说明:数组中可以存放一个变量,但是字符串形式只能存放常量
(3) 对象:如果表达式计算为对象,则对于具有真值的对象的每个键值对,相应的键用作类名。
<div ng-class {'selected': isSelected, 'car': isCar}">
说明:当 isSelected = true 则增加selected class,当isCar=true,则增加car class,
2、ng-style
ng-style的属性值是一个对象,对象里的内容是以key->value的形式展现,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 指令用于在表达式为 false 时,移除指定html元素,当表达式为true时,则添加移除的html元素,并显示,如下:
<div ng-if='vm.text'>{{vm.progress}}%</div>
说明:当vm.text为真时显示视图里面的内容,否则移除
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>
说明:在select标签中,ng-model的值为所选择的option的value值
<input type="checkbox" ng-model='vm.text'>
说明:在checkbox中,ng-model的值为true或者false
更多关于AngularJS相关内容感兴趣的读者可查看本站专题:《AngularJS指令操作技巧总结》、《AngularJS入门与进阶教程》及《AngularJS MVC架构总结》
希望本文所述对大家AngularJS程序设计有所帮助。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 《怪猎荒野》PS5Pro主机版对比:B测性能都不稳定
- 黄宝欣.1992-黄宝欣金装精选2CD【HOMERUN】【WAV+CUE】
- 群星.1996-宝丽金流行爆弹精丫宝丽金】【WAV+CUE】
- 杜德伟.2005-独领风骚新歌精选辑3CD【滚石】【WAV+CUE】
- 安与骑兵《心无疆界》[低速原抓WAV+CUE]
- 柏菲唱片-群星〈胭花四乐〉2CD[原抓WAV+CUE]
- 金典女声发烧靓曲《ClassicBeautifulSound》2CD[低速原抓WAV+CUE]
- 王杰1992《封锁我一生》粤语专辑[WAV+CUE][1G]
- 群星《一人一首成名曲 (欧美篇)》6CD[WAV/MP3][7.39G]
- 东来东往2004《回到我身边·别说我的眼泪你无所谓》先之唱片[WAV+CUE][1G]
- MF唱片-《宝马[在真HD路上]》2CD[低速原抓WAV+CUE]
- 李娜《相信我》新时代[WAV+CUE]
- 2019明达发烧碟MasterSuperiorAudiophile[WAV+CUE]
- 蔡幸娟.1993-相爱容易相处难【飞碟】【WAV+CUE】
- 陆虎.2024-是否愿意成为我的全世界【Hikoon】【FLAC分轨】