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 相关文章推荐
ASP.NET jQuery 实例9  通过控件hyperlink实现返回顶部效果
Feb 03 Javascript
window.showModalDialog()返回值的学习心得总结
Jan 07 Javascript
jquery获取当前日期的方法
Jan 14 Javascript
gulp-uglify 与gulp.watch()配合使用时报错(重复压缩问题)
Aug 24 Javascript
JavaScript数据类型和变量_动力节点Java学院整理
Jun 26 Javascript
初学者AngularJS的环境搭建过程
Oct 27 Javascript
Node.js 多进程处理CPU密集任务的实现
May 26 Javascript
Vue指令之 v-cloak、v-text、v-html实例详解
Aug 08 Javascript
JS面向对象编程实现的Tab选项卡案例详解
Mar 03 Javascript
返回上一个url并刷新界面的js代码
Sep 12 Javascript
在antd Table中插入可编辑的单元格实例
Oct 28 Javascript
jquery插件实现悬浮的菜单
Apr 24 jQuery
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
全国FM电台频率大全 - 17 湖北省
2020/03/11 无线电
《Re:从零开始的异世界生活 冰结之绊》
2020/04/09 日漫
探讨php中防止SQL注入最好的方法是什么
2013/06/10 PHP
PHP输出XML格式数据的方法总结
2017/02/08 PHP
由浅到深了解JavaScript类
2006/09/08 Javascript
通用JS事件写法实现代码
2009/01/07 Javascript
jQuery 创建Dom元素
2010/05/07 Javascript
javascript event 事件解析
2011/01/31 Javascript
优化Jquery,提升网页加载速度
2013/11/14 Javascript
jquery判断iPhone、Android设备类型
2016/09/14 Javascript
angularjs select 赋值 ng-options配置方法
2018/02/28 Javascript
详解vue项目中如何引入全局sass/less变量、function、mixin
2018/06/02 Javascript
Vue项目自动转换 px 为 rem的实现方法
2018/10/29 Javascript
基于vue写一个全局Message组件的实现
2019/08/15 Javascript
JavaScript中的全局属性与方法深入解析
2020/06/14 Javascript
python实现保存网页到本地示例
2014/03/16 Python
Python实现股市信息下载的方法
2015/06/15 Python
Python简单计算文件夹大小的方法
2015/07/14 Python
python处理按钮消息的实例详解
2017/07/11 Python
详解Python使用tensorflow入门指南
2018/02/09 Python
Python中str.join()简单用法示例
2018/03/20 Python
python+flask实现API的方法
2018/11/21 Python
python+unittest+requests实现接口自动化的方法
2018/11/29 Python
Python 实现一个手机号码获取妹子名字的功能
2019/09/25 Python
从numpy数组中取出满足条件的元素示例
2019/11/26 Python
用Python去除图像的黑色或白色背景实例
2019/12/12 Python
浅谈Keras的Sequential与PyTorch的Sequential的区别
2020/06/17 Python
python爬虫请求头的使用
2020/12/01 Python
is_file和file_exists效率比较
2021/03/14 PHP
英国轻奢珠宝品牌:Astley Clarke
2016/12/18 全球购物
升旗仪式主持词
2014/03/19 职场文书
如何写一份好的英文求职信
2014/03/19 职场文书
走进科学观后感
2015/06/18 职场文书
护士业务学习心得体会
2016/01/25 职场文书
Django migrate报错的解决方案
2021/05/20 Python
使用CSS实现按钮边缘跑马灯动画
2023/05/07 HTML / CSS