Angular-UI Bootstrap组件实现警报功能


Posted in Javascript onJuly 16, 2018

Angular-UI Bootstrap提供了许多组件,从流行的的Bootstrap项目移植到Angular 指令(显著的减少了代码量)。如果你计划在Angular应用中使用Bootstrap组件,我建议细心检查。话虽如此,直接使用Bootstrap,应该也是可以工作的。

Angular controller可以共享service的代码。警报就是把service代码共享到controller的很好用例之一。

Angular-UI Bootstrap文档提供了下面的例子:

view

<div ng-controller="AlertDemoCtrl">
 <alert ng-repeat="alert in alerts" type="alert.type" close="closeAlert($index)">{{alert.msg}}</alert>
 <button class='btn' ng-click="addAlert()">Add Alert</button>
</div>

controller

function AlertDemoCtrl($scope) {
 $scope.alerts = [
  { type: 'error', msg: 'Oh snap! Change a few things up and try submitting again.' }, 
  { type: 'success', msg: 'Well done! You successfully read this important alert message.' }
 ];

 $scope.addAlert = function() {
  $scope.alerts.push({msg: "Another alert!"});
 };

 $scope.closeAlert = function(index) {
  $scope.alerts.splice(index, 1);
 };
}

鉴于我们要在app中的不同的控制器中创建警报,并且跨控制器的代码不好引用,我们将要把它移到service中。

alertService

'use strict';
/* services.js */
// don't forget to declare this service module as a dependency in your main app constructor!
var appServices = angular.module('appApp.services', []);
appServices.factory('alertService', function($rootScope) {
  var alertService = {};
  // create an array of alerts available globally
  $rootScope.alerts = [];
  alertService.add = function(type, msg) {
   $rootScope.alerts.push({'type': type, 'msg': msg});
  };
  alertService.closeAlert = function(index) {
   $rootScope.alerts.splice(index, 1);
  };
  return alertService;
 });

view

<div>
 <alert ng-repeat="alert in alerts" type="alert.type" close="closeAlert($index)">{{ alert.msg }}</alert>
</div>

最后,我们需要将alertService's中的closeAlert()方法绑定到$globalScope。

controller

function RootCtrl($rootScope, $location, alertService) {
 $rootScope.changeView = function(view) {
  $location.path(view);
 }
 // root binding for alertService
 $rootScope.closeAlert = alertService.closeAlert; 
}
RootCtrl.$inject = ['$scope', '$location', 'alertService'];

我不完全赞同这种全局绑定,我希望的是直接从警报指令中的close data属性中调用service方法,我不清楚为什么不这样来实现。

现在创建一个警报只需要从你的任何一个控制器中调用alertService.add()方法。

function ArbitraryCtrl($scope, alertService) {
 alertService.add("warning", "This is a warning.");
 alertService.add("error", "This is an error!");
}

总结

以上所述是小编给大家介绍的Angular-UI Bootstrap组件实现警报功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jQuery中[attribute!=value]选择器用法实例
Dec 31 Javascript
jQuery实现鼠标悬停背景翻转的黑色导航菜单代码
Sep 14 Javascript
javascript单页面手势滑屏切换原理详解
Mar 21 Javascript
DOM操作和jQuery实现选项移动操作的简单实例
Jun 07 Javascript
vuejs2.0运用原生js实现简单的拖拽元素功能示例
Feb 24 Javascript
详解利用jsx写vue组件的方法示例
Jul 17 Javascript
vue实现仿淘宝结账页面实例代码
Nov 08 Javascript
深入浅析AngularJs模版与v-bind
Jul 06 Javascript
微信小程序textarea层级过高的解决方法
Mar 04 Javascript
vue实现记事本功能
Jun 26 Javascript
JavaScript实现跟随鼠标移动的盒子
Jan 28 Javascript
JavaScript实现手风琴效果
Feb 18 Javascript
JS在if中的强制类型转换方式
Jul 15 #Javascript
微信小程序form表单组件示例代码
Jul 15 #Javascript
微信小程序仿朋友圈发布动态功能
Jul 15 #Javascript
Bootstrap Table中的多选框删除功能
Jul 15 #Javascript
详解JavaScript 中 if / if...else...替换方式
Jul 15 #Javascript
简述JS控制台的使用
Jul 15 #Javascript
简述JS浏览器的三种弹窗
Jul 15 #Javascript
You might like
用 php 编写的日历
2006/10/09 PHP
php 破解防盗链图片函数
2008/12/09 PHP
php实现的Captcha验证码类实例
2014/09/22 PHP
TP5多入口设置实例讲解
2020/12/15 PHP
javascript判断变量是否有值的方法
2015/04/20 Javascript
JavaScript数组迭代器实例分析
2015/06/09 Javascript
js实现黑色简易的滑动门网页tab选项卡效果
2015/08/31 Javascript
很全面的JavaScript常用功能汇总集合
2016/01/22 Javascript
AngularJS手动表单验证
2016/02/01 Javascript
JavaScript实现点击按钮字体放大、缩小
2016/02/29 Javascript
基于Bootstrap实现tab标签切换效果
2020/04/15 Javascript
详解vue与后端数据交互(ajax):vue-resource
2017/03/16 Javascript
解读vue生成的文件目录结构及说明
2017/11/27 Javascript
基于Vue自定义指令实现按钮级权限控制思路详解
2018/05/23 Javascript
JS实现的雪花飘落特效示例
2019/12/03 Javascript
Vue中引入svg图标的两种方式
2021/01/14 Vue.js
vue浏览器返回监听的具体步骤
2021/02/03 Vue.js
[01:20:30]OG vs LGD 2018国际邀请赛淘汰赛BO3 第四场 8.26
2018/08/30 DOTA
python测试驱动开发实例
2014/10/08 Python
Python基于DES算法加密解密实例
2015/06/03 Python
Python使用uuid库生成唯一标识ID
2020/02/12 Python
详解Pycharm出现out of memory的终极解决方法
2020/03/03 Python
Python 多线程共享变量的实现示例
2020/04/17 Python
python Django 反向访问器的外键冲突解决
2020/05/20 Python
python对批量WAV音频进行等长分割的方法实现
2020/09/25 Python
HTML5混合开发二维码扫描以及调用本地摄像头
2017/12/27 HTML / CSS
SmartBuyGlasses丹麦:网上购买名牌太阳镜、眼镜和隐形眼镜
2016/10/01 全球购物
Dune London官网:英国著名奢华鞋履品牌
2017/11/30 全球购物
商务英语毕业生自荐信范文
2013/11/08 职场文书
高中语文教学反思
2014/01/16 职场文书
岗位廉洁从政承诺书
2014/03/27 职场文书
小学五年级学生评语
2014/04/22 职场文书
安全生产演讲稿
2014/05/09 职场文书
教师求职自荐信
2015/03/26 职场文书
导游词之蜀山胜景瓦屋山
2019/11/29 职场文书
MySQL基础(一)
2021/04/05 MySQL