将angular-ui-bootstrap的弹出框定义成一个服务的实践
定义一个弹出框的服务:alert_box
defiine(["app"],function(mainapp){
mainapp.controller('ModalInstanceCtrl',[ "$scope","$uibModalInstance","items",function ($scope, $uibModalInstance, items) {
$scope.items = items;//来自服务的resolve
$scope.selected = {
item: $scope.items[0]
};
//对应于服务then的第一个函数
$scope.ok = function () {//点击”确定“按钮
$uibModalInstance.close($scope.selected.item);
};
//对应于then的第二个服务
$scope.cancel = function () {//点击”取消“按钮
$uibModalInstance.dismiss('cancel');
};
})];
mainapp.factory("alert_box",["$uibModal","$log",function($uibModal,$log){
var alert_box={};
alert_box.change_team(){
var items=["测试1","测试2","测试3"];
var modalInstance=$uibModal.open({
animation:true,
templateUrl:"js/service/myModal/modal_alert.html",
controller:"ModalInstanceCtrl",
size:"large",
resolve:{//保证在js服务加载之前,先执行(注入一个items,用于将服务里面的数据传递到控制器)
items:function(){
return items;
}
}
});
modalInstance.result.then( //then的第一个函数对应ok(),第二个函数对应cancel()
function(sel){console.log(sel)},
function(){console.log(”用户取消操作“);}
);
}
return alert_box;
}]);
});
弹出框服务的使用:(我这里是在一个指令里面调用的)
define(["app","js/service/myModel/model_alert"],function(mainapp){//引入服务文件
mainapp.directive('myheader',[function(){
return{
replace:true,
templateUrl:"directive_tpls/header.html",//指令的模版页面
controller:["$scope","alert_box",function($scope,alert_box){
.......///
其他的业务逻辑神略
.......///
$scope.openmodel=function(){
alert_box.change_team();//通过服务调用
}
}]
}
}]);
});
然后就可以在指令的模版页面中调用
例如:<div ng-click="openmodal()"></div>
以上的封装似乎还是来的简单,下面再来一次进阶封装
1)还是定义一个服务
define(['app','js/service/myModal/modal_ctrl'],function(mainapp){
mainapp.factory('alert_box',['$uibModal','$log',function($uibModal,$log){
var alert_box={};
alert_box.open_modal=function(obj){
var items=obj.info;
return $uibModal.open({
animate:obj.animate,
templateUrl:obj.tpl_url,
controller:obj.self_ctrl,
size:obj.size,
resolve:{
items:function(){
return items;//这个参数可以在弹出框控制器中注入,用于页面控制器向弹出框控制器传参数
}
}
})
}
}]);
});
2)modal_ctrl,我这里是将所有的弹出框控制器,集中在这里(遍历管理),当然你也可以直接写在上面的服务中
js/service/myModal/modal_ctrl
define(['app',
"js/service/addApplicant/checkbox_add_applicant",
'js/service/choiceInventors/choice_add_inventors',
'js/service/alertModal/cofirm'
],function(mainapp){
mainapp.registerController("modal_ctrl",[function(){ }]);
});
3)定义弹出框Ctrl,用于弹出框模版的数据交互处理
define(['app'],function(mainapp){
mainapp.registerController("checkboxAddInventors",['$uibModalInstance','$scope','items',function($uibModalInstance,$scope){
/*
给页面确定,取消按钮两个事件(通过这两个方法可以将数据信息传递给服务)
*/
$scope.sure=function(){
$uibModalInstance.close("点击确定按钮");
}
$scope.cancel=function(){
$uibModalInstance.dismiss("点击取消按钮");
}
}]);
});
4)在这里省略弹出框模版了:js/service/choiceInventors/checkbox_add_Invertors.html
5)在页面控制器使用弹出框服务
define(['app'
,'js/service/modal_alert'
],function(mainapp){
mainapp.registerCtroller("addCtrl",['$scope','alert_modal',function($scope,alert_modal){
/*
给他一个触发事件
*/
$scope.open=function(){
alert_box.open_modal({
tpl_url:'js/service/choiceInventors/checkbox_add_Invertors.html',
self_ctrl:'checkboxAddInvertors',
size:870,
animate:true }).then(function(res){//点击确定按钮的回调函数 },function(res){//点击取消的回调函数 });
} }]); });
页面控制器-------------------resolve:{ }-------------------->弹出框模版控制器
弹出框控制器------------回调函数------------------------------>页面控制器
注意:使用的版本
在自定义服务时,是不能注入$scope的
http://angular-ui.github.io/bootstrap/versioned-docs/1.3.1/#/modal
将angular-ui-bootstrap的弹出框定义成一个服务的实践的更多相关文章
- angular-ui-bootstrap的弹出框定义成一个服务的实践(二)
定义一个弹出框的服务:alert_box defiine(["app"],function(mainapp){ mainapp.controller('ModalInstanceC ...
- Bootstrap:弹出框和提示框效果以及代码展示
前言:对于Web开发人员,弹出框和提示框的使用肯定不会陌生,比如常见的表格新增和编辑功能,一般常见的主要有两种处理方式:行内编辑和弹出框编辑.在增加用户体验方面,弹出框和提示框起着重要的作用,如果你的 ...
- JS组件Bootstrap实现弹出框和提示框效果代码
这篇文章主要介绍了JS组件Bootstrap实现弹出框和提示框效果代码,对弹出框和提示框感兴趣的小伙伴们可以参考一下 前言:对于Web开发人员,弹出框和提示框的使用肯定不会陌生,比如常见的表格新增和编 ...
- Bootstrap模态弹出框
前面的话 在 Bootstrap 框架中把模态弹出框统一称为 Modal.这种弹出框效果在大多数 Web 网站的交互中都可见.比如点击一个按钮弹出一个框,弹出的框可能是一段文件描述,也可能带有按钮操作 ...
- Bootboxjs快速制作Bootstrap的弹出框效果
Bootboxjs是一个简单的js库,简单快捷帮你制作一个Bootstrap的弹出框效果. 一.简介 bootbox.js是一个小的JavaScript库,它帮助您在使用bootstrap框架的时候快 ...
- [Bootstrap]modal弹出框
写在前面 在实际开发中,为了友好,更需要一种美观的弹出框,js原生的alert,很难满足需求.这里推荐一个bootstrap的弹出框. 一个例子 先看效果吧 代码: <!DOCTYPE html ...
- Bootstrap实现弹出框和提示框效果代码
一.Bootstrap弹出框使用过JQuery UI应该知道,它里面有一个dialog的弹出框组件,功能也很丰富.与jQuery UI的dialog类似,Bootstrap里面也内置了弹出框组件.打开 ...
- Bootstrap popover弹出框
popover被挤压.遮挡的问题: 弹出框显示的时候如果贴近一个列的边沿,就会很窄或被遮挡,解决起来很简单,只需在初始化的时候添加一个container属性就可以了: $(function (){ $ ...
- 自定义Bootstrap样式弹出框
最近做的一些功能需要用到Bootstrap,然而原来的系统并没有引入Bootstrap,为了新写的控件能够应用于老的页面,又不需要在老的页面上引入全套的Bootstrap文件决定写一个模仿Bootst ...
随机推荐
- 基于django做HTTP代理服务器
计算机网络的一次小实验,最后一共用了不到100行 实现了: a) 网站过滤:允许/不允许访问某些网站: b) 用户过滤:支持/不支持某些用户访问外部网站: c) 网站引导:将用户对某个网站的访问引导至 ...
- POJ 1007
DNA Sorting Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 83069 Accepted: 33428 Descrip ...
- poj1011 搜索+剪枝
DFS+剪枝 POJ2362的强化版,重点在于剪枝 令InitLen为所求的最短原始棒长,maxlen为给定的棒子堆中最长的棒子,sumlen为这堆棒子的长度之和,那么InitLen必定在范围[max ...
- Java 7之基础 - 强引用、弱引用、软引用、虚引用
1.强引用(StrongReference) 强引用是使用最普遍的引用.如果一个对象具有强引用,那垃圾回收器绝不会回收它.如下: Object o=new Object(); // 强引用 当内 ...
- $>_<$
Hello word! 从jdk环境变量的配置,myeclipse的安装,tomcat的部署和使用,面向对象的编程思想,什么是java. 思维从模糊到清晰,一路摸索,不见泰山!
- select多用户之间通信
查看记录:10/20 今天又重新看了一下程序,觉得ListenKeyboard这个函数写的很好.利用select监听键盘,成功的解决了 必须输入才会刷新消息的问题.这样等待15秒后也可刷新消息,效 ...
- gitignore.io-程序猿值得拥有的智能生成gitignore文件的秘密武器
gitignore.io Create useful .gitignore files for your project by selecting from 360 Operating System, ...
- 深入理解Activity的启动模式
众所周知,当我们多次启动同一个Activity时,会创建多个该Activity的实例,系统会按照先进后出的原则,将它们一一放进任务栈中,然后我们按back键,系统就会将栈顶的Activity移除栈,直 ...
- Reverse Integer 2015年6月23日
题目: Reverse digits of an integer. Example1: x = , return Example2: x = -, return - 思路:递归 解答: / test ...
- Ultimus BPM 通信和运营商行业应用解决方案
Ultimus BPM 通信和运营商行业应用解决方案 行业应用需求 电信运营商的主要职能是维护庞大的通信网络和向电信用户提供固话通讯.手机通讯.数据通讯及相关的附加增值服务,其组织特点是工种多.分工细 ...