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_boxdefiine(["app"],function(mainapp){ mainapp.controller('ModalInstanceCt ...
- 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 ...
随机推荐
- ngnix配置自解
全局配置 user [user] [group]; #只有被设置为用户或用户组的成员才有nginx的启动权限.(#user nobody nobody <=> user nobody no ...
- 5G信令(就是用户身份信息)风暴——就是客户端通过公钥加密的消息(携带手机IMSI号)发给服务端,服务器需用私钥解密,这个解密比较消耗资源,如果短时间大量请求到来就会触发信令风暴
信令:手机开机后,先从USIM中读取之前运营商分配的临时身份信息GUTI/TMSI,发送携带该身份信息的信令给基站,请求接入运营商网络. 如果每个设备的每条消息都需要单独认证,则网络侧安全信令的验证需 ...
- 使用XMLHttpRequest对象完成原生的AJAX请求
1.大家眼中的Ajax 说到Ajax,只要有过前端开发经验的童鞋一定都不陌生,大都知道它就是一种与后端之间的通信技术,通过这个神奇的家伙,我们不用像传统表单那样填完信息一点提交就呼啦呼啦跳转了.Aja ...
- bzoj1800
题解: 暴力枚举,然后判断是否是矩形 代码: #include<iostream> #include<cstdio> using namespace std; ],dis[]; ...
- 内存保护机制及绕过方法——利用Ret2Libc绕过DEP之VirtualProtect函数
利用Ret2Libc绕过DEP之VirtualProtect函数 ⑴. 原理分析: i.相关概念: VirtualProtect()函数: BOOL WINAPI VirtualProtect( _ ...
- eureka -2 - 重要配置
Server 端配置 eureka.client.registerWithEureka :是否将自己注册到Eureka Server,默认是true,如果是单节点部署,切是server端,则设置成fa ...
- 关于Qt中使用线程的时候函数具体在哪个线程中运行的问题
在子线程中,run函数中以及其中调用的都在单独的子线程里面运行,但是其他的类似构造函数之流都是在主线程里面运行的,不要搞混了
- php 请求url获取状态码
function get_http_code($url) { $curl = curl_init(); curl_setopt($curl, CURLOPT_URL, $url); //设置URL c ...
- Js 日期选择,可以的一个页面中重复使用本JS日历,兼容IE及火狐等主流浏览器,而且界面简洁、美观,操作体验也不错。
<html> <head> <title>Js日期选择器并自动加入到输入框中</title> <meta http-equiv="con ...
- asp.net button浏览器端事件和服务器端事件
OnClientClick:触发浏览器端的响应,OnClick触发服务器端响应; 在服务器aspx.cs脚本中设置按钮属性: this.btnTest.Attributes["OnClick ...