AngularJS实现进度条功能示例


Posted in Javascript onJuly 05, 2017

本文实例讲述了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预览:

AngularJS实现进度条功能示例

三、知识点分析

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程序设计有所帮助。

Javascript 相关文章推荐
jquery 简短右键菜单 多浏览器兼容
Jan 01 Javascript
将HTMLCollection/NodeList/伪数组转换成数组的实现方法
Jun 20 Javascript
JavaScript 验证码的实例代码(附效果图)
Mar 22 Javascript
JS实现单击输入框弹出选择框效果完整实例
Dec 14 Javascript
[Bootstrap-插件使用]Jcrop+fileinput组合实现头像上传功能实例代码
Dec 20 Javascript
canvas知识总结
Jan 25 Javascript
ztree加载完成后显示勾选节点的实现代码
Oct 22 Javascript
详解JavaScript中的强制类型转换
Apr 15 Javascript
webpack4手动搭建Vue开发环境实现todoList项目的方法
May 16 Javascript
Vue.js递归组件实现组织架构树和选人功能案例分析
Jul 03 Javascript
vue-mugen-scroll组件实现pc端滚动刷新
Aug 16 Javascript
javascript 设计模式之享元模式原理与应用详解
Apr 08 Javascript
AngularJS实现tab选项卡的方法详解
Jul 05 #Javascript
angularjs2中父子组件的数据传递的实例代码
Jul 05 #Javascript
jQuery制作input提示内容(兼容IE8以上)
Jul 05 #jQuery
jQuery常见面试题之DOM操作详析
Jul 05 #jQuery
详解基于angular-cli配置代理解决跨域请求问题
Jul 05 #Javascript
微信小程序学习之数据处理详解
Jul 05 #Javascript
用node和express连接mysql实现登录注册的实现代码
Jul 05 #Javascript
You might like
yii操作cookie实例简介
2014/07/09 PHP
在IE6下发生Internet Explorer cannot open the Internet site错误
2010/06/21 Javascript
分享2个jQuery插件--jquery.fileupload与artdialog
2014/12/26 Javascript
javascript设计模式之对象工厂函数与构造函数详解
2015/07/30 Javascript
纯javascript移动优先的幻灯片效果
2015/11/02 Javascript
谈谈Jquery ajax中success和complete有哪些不同点
2015/11/20 Javascript
js中的关联数组与普通数组详解
2016/07/27 Javascript
用NodeJS实现批量查询地理位置的经纬度接口
2016/08/16 NodeJs
JavaScript html5利用FileReader实现上传功能
2020/03/27 Javascript
vue2.0中goods选购栏滚动算法的实现代码
2017/05/17 Javascript
nodejs socket实现的服务端和客户端功能示例
2017/06/02 NodeJs
js获取元素的偏移量offset简单方法(必看)
2017/07/05 Javascript
vue select二级联动第二级默认选中第一个option值的实例
2018/01/10 Javascript
集成vue到jquery/bootstrap项目的方法
2018/02/10 jQuery
vue学习笔记之给组件绑定原生事件操作示例
2020/02/27 Javascript
js实现无限层级树形数据结构(创新算法)
2020/02/27 Javascript
JS中间件设计模式的深入探讨与实例分析
2020/04/11 Javascript
[03:09]2014DOTA2国际邀请赛 赛场上的美丽风景线 中国Coser也爱DOTA2
2014/07/20 DOTA
python并发编程之多进程、多线程、异步和协程详解
2016/10/28 Python
浅谈Python peewee 使用经验
2017/10/20 Python
python创建列表和向列表添加元素的实现方法
2017/12/25 Python
Python 实现文件打包、上传与校验的方法
2019/02/13 Python
CSS3控制HTML元素动画效果
2014/02/08 HTML / CSS
美国设计师精美珠宝购物网:Netaya
2016/08/28 全球购物
德国、奥地利和瑞士最大的旅行和度假门户网站:HolidayCheck
2019/11/14 全球购物
Monica Vinader官网:英国轻奢珠宝品牌
2020/02/05 全球购物
AJAX的优缺点都有什么
2015/08/18 面试题
员工合理化建议书
2014/05/19 职场文书
欢迎领导标语
2014/06/27 职场文书
县政府办公室领导班子对照检查材料思想汇报
2014/09/28 职场文书
2014年小学教导处工作总结
2014/12/19 职场文书
新员工试用期自我评价
2015/03/10 职场文书
离婚案件答辩状
2015/05/22 职场文书
JavaScript组合继承详解
2021/11/07 Javascript
分享mysql的current_timestamp小坑及解决
2021/11/27 MySQL
Android Studio实现带三角函数对数运算功能的高级计算器
2022/05/20 Java/Android