将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 ...
随机推荐
- Tomcat 热部署
Tomcat热部署就是实现不停机的发布项目和更新项目 1.修改conf目录下的tomcat-users.xml文件 在<tomcat-user>添加如下配置 [root@localhost ...
- 小米Adnroid默认禁止悬浮框的使用,导致开发的悬浮框无法接收事件
比如你建了一个悬浮框: WindowManager windowManager = getWindowManager(context); int screenWidth = windowManager ...
- Python安装mysqldb
1.根据Python版本和自己的系统下载mysqldb http://www.codegood.com/downloads
- hadoop集群中删除原有jdk设置
普通用户: sudo rpm -e --nodeps java-1.6.0-openjdk-1.6.0.0-1.50.1.11.5.el6_3.x86_64 tzdata-java-2012j-1.e ...
- Vmware虚拟机中安装cnetOS7详细图解步骤
1.安装VMware 下载一个软件安装: .新建一个虚拟机 .引用安装包 4.启动新建的虚拟机 .安装CentOS7的步骤 配置系统语言: 配置系统时间: 配置系统键盘: 配置键盘切换的快捷键: 配置 ...
- CATransition 转场动画解析
http://blog.csdn.net/mad2man/article/details/17260901
- vim 和grep 正则表达式相似和区别
正则表达式由两种基本字符类型组成:原义(正常)文本字符和元字符.元字符使正则表达式具有处理能力.所谓元字符就是指那些在正则表达式中具有特殊意义的专用字符,可以用来规定其前导字符(即位于元字符前面的字符 ...
- Java并发编程:Callable、Future和FutureTask的实现
启动线程执行任务,如果需要在任务执行完毕之后得到任务执行结果,可以使用从Java 1.5开始提供的Callable和Future 下面就分析一下Callable.Future以及FutureTask的 ...
- 【flex弹性盒布局】------这个强大的功能
你知道flex弹性布局么? 我们先来了解它的概念:Flex是Flexible Box的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性. 任何一个容器都可以指定为Flex布局 ...
- Java Date Classes
References: [1] http://tutorials.jenkov.com/java-date-time/index.html [2] https://docs.oracle.com/ja ...