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 相关文章推荐
Prototype 学习 工具函数学习($w,$F方法)
Jul 12 Javascript
Jquery 动态添加按钮实现代码
May 06 Javascript
Javascript中 关于prototype属性实现继承的原理图
Apr 16 Javascript
JavaScript中的fontsize()方法使用详解
Jun 08 Javascript
javascript常用的方法分享
Jul 01 Javascript
JavaScript自定义分页样式
Jan 17 Javascript
Vue中的v-cloak使用解读
Mar 27 Javascript
在vue组件中使用axios的方法
Mar 16 Javascript
Vue项目数据动态过滤实践及实现思路
Sep 11 Javascript
vue 解决遍历对象显示的顺序不对问题
Nov 07 Javascript
vue 判断页面是首次进入还是再次刷新的实例
Nov 05 Javascript
vue组件vue-esign实现电子签名
Apr 21 Vue.js
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
支持中文的php加密解密类代码
2011/11/27 PHP
PHP FATAL ERROR: CALL TO UNDEFINED FUNCTION BCMUL()解决办法
2014/05/04 PHP
php+memcache实现的网站在线人数统计代码
2014/07/04 PHP
php实现的一段简单概率相关代码
2016/05/30 PHP
PHP魔术方法之__call与__callStatic使用方法
2017/07/23 PHP
一款JavaScript压缩工具:X2JSCompactor
2007/06/13 Javascript
基于jquery跨浏览器显示的file上传控件
2011/10/24 Javascript
js点击页面其它地方将某个显示的DIV隐藏
2012/07/12 Javascript
javascript删除数组元素并且数组长度减小的简单实例
2014/02/14 Javascript
JS获取图片高度宽度的方法分享
2015/04/17 Javascript
详解JavaScript中数组的相关知识
2015/07/29 Javascript
javascript实现输出指定行数正方形图案的方法
2015/08/03 Javascript
JavaScript中Textarea滚动条不能拖动的解决方法
2015/12/15 Javascript
利用JS提交表单的几种方法和验证(必看篇)
2016/09/17 Javascript
原生js实现鼠标跟随效果
2017/02/28 Javascript
二维码图片生成器QRCode.js简单介绍
2017/08/18 Javascript
js定时器+简单的动画效果实例
2017/11/10 Javascript
jQuery实现验证表单密码一致性及正则表达式验证邮箱、手机号的方法
2017/12/05 jQuery
Bootstrap treeview实现动态加载数据并添加快捷搜索功能
2018/01/07 Javascript
JavaScript引用类型Date常见用法实例分析
2018/08/08 Javascript
JS实现的合并两个有序链表算法示例
2019/02/25 Javascript
微信小程序生成二维码的示例代码
2019/03/29 Javascript
[02:11]2014DOTA2 TI专访VG战队Fenrir:队伍气氛良好
2014/07/11 DOTA
Python3基础之函数用法
2014/08/13 Python
Python正则抓取网易新闻的方法示例
2017/04/21 Python
python实现微信远程控制电脑
2018/02/22 Python
Python统计python文件中代码,注释及空白对应的行数示例【测试可用】
2018/07/25 Python
如何在django里上传csv文件并进行入库处理的方法
2019/01/02 Python
Python 闭包,函数分隔作用域,nonlocal声明非局部变量操作示例
2019/10/14 Python
捷克厨房用品购物网站:Tescoma
2018/07/13 全球购物
英国家居装饰品、户外家具和玻璃器皿购物网站:Rinkit.com
2019/11/04 全球购物
俄罗斯便宜的在线服装商店:GroupPrice
2020/04/10 全球购物
《和我们一样享受春天》教学反思
2014/02/07 职场文书
旅游文化节策划方案
2014/06/06 职场文书
2014年体育部工作总结
2014/11/13 职场文书
Python编程中内置的NotImplemented类型的用法
2022/03/23 Python