ionic模态窗口

ionic 模态窗口

$ionicModal

$ionicModal 可以遮住用户主界面的内容框。
你可以在你的 index 文件或者是其他文件内嵌入以下代码(里面的代码可以根据你自己的业务场景相应的改变)。

<script id="my-modal.html" type="text/ng-template"> 
  <ion-modal-view> 
    <ion-header-bar> 
      <h1 class="title">My Modal title</h1> 
    </ion-header-bar> 
    <ion-content> Hello! </ion-content> 
  </ion-modal-view>
</script>

然后你就可以在你的 Controller 里面的注入 $ionicModal 。然后调用你刚刚写入的模板,进行初始化操作。就像下面的代码:

angular.module('testApp', ['ionic'])
.controller('MyController', function($scope, $ionicModal) { 
  $ionicModal.fromTemplateUrl('my-modal.html', { 
    scope: $scope, 
    animation: 'slide-in-up' 
  }).then(function(modal) { 
    $scope.modal = modal; 
  }); 
  $scope.openModal = function() { 
    $scope.modal.show(); 
  }; 
  $scope.closeModal = function() { 
    $scope.modal.hide(); 
  }; 
  //Cleanup the modal when we're done with it! 
  $scope.$on('$destroy', function() { 
    $scope.modal.remove(); 
  }); 
  // Execute action on hide modal 
  $scope.$on('modal.hidden', function() { 
    // Execute action
  }); 
  // Execute action on remove modal 
  $scope.$on('modal.removed', function() { 
    // Execute action 
  });
});
方法
fromTemplate(templateString, options)
参数 类型 详情
templateString 字符串 模板的字符串作为模态窗口的内容。
options 对象 options 会传递到 ionicModal#initialize方法中。

返回: 对象, 一个ionicModal控制器的实例。

fromTemplateUrl(templateUrl, options)
参数 类型 详情
templateUr 字符串 载入模板的url。
options 对象 通过ionicModal#initialize方法传递对象。

返回: promise对象。Promises对象是CommonJS工作组提出的一种规范,目的是为异步编程提供统一接口。

ionicModal

由$ionicModal服务实例化。
提示:当你完成每个模块清除时,确保调用remove()方法,以避免内存泄漏。
注意:一个模块从它的初始范围广播出 'modal.shown' 和 'modal.hidden' ,把自身作为一个参数来传递。

方法
initialize(可选)

创建一个新的模态窗口控制器示例。

参数 类型 详情
options 对象 <small>一个选项对象具有一下属性:
  {object=} 范围 子类的范围。默认:创建一个$rootScope子类。
  {string=} 动画 带有显示或隐藏的动画。默认:'slide-in-up'
  {boolean=} 第一个输入框获取焦点 当显示时,模态窗口的第一个输入元素是否自动获取焦点。默认:false。
  {boolean=} backdropClickToClose` 点击背景时是否关闭模态窗口。默认:true。</small>
show()

显示模态窗口实例

  • 返回值: <small>promise</small> promise对象,在模态窗口完成动画后得到解析

    hide()
    

隐藏模态窗口。

  • 返回值: <small>promise</small> promise对象,在模态窗口完成动画后得到解析

    remove()
    

从 DOM 中移除模态窗口实例并清理。

  • 返回值: <small>promise</small> promise对象,在模态窗口完成动画后得到解析

    isShown()
    
  • 返回:布尔值,用于判断模态窗口是否显示。

实例

【HTML 代码】

<html ng-app="ionicApp"> 
  <head> 
    <meta charset="utf-8"> 
    <meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no, width=device-width"> 
    <title>菜鸟教程(runoob.com)</title> 
    <link href="http://www.runoob.com/static/ionic/css/ionic.min.css" rel="stylesheet"> 
    <script src="http://www.runoob.com/static/ionic/js/ionic.bundle.min.js"></script> 
  </head> 

  <body ng-controller="AppCtrl"> 

    <ion-header-bar class="bar-positive"> 
      <h1 class="title">Contacts</h1> 
      <div class="buttons"> 
        <button class="button button-icon ion-compose" ng-click="modal.show()"> </button> 
      </div> 
    </ion-header-bar> 

    <ion-content> 
      <ion-list> 
        <ion-item ng-repeat="contact in contacts"> 
          {{contact.name}} 
        </ion-item> 
      </ion-list> 
    </ion-content> 

    <script id="templates/modal.html" type="text/ng-template"> 
      <ion-modal-view> 

        <ion-header-bar class="bar bar-header bar-positive"> 
          <h1 class="title">New Contact</h1> 
          <button class="button button-clear button-primary" ng-click="modal.hide()">Cancel</button> 
        </ion-header-bar> 

        <ion-content class="padding"> 
          <div class="list"> 

            <label class="item item-input"> 
              <span class="input-label">First Name</span> 
              <input ng-model="newUser.firstName" type="text"> 
            </label> 

            <label class="item item-input"> 
              <span class="input-label">Last Name</span> 
              <input ng-model="newUser.lastName" type="text"> 
            </label> 

            <label class="item item-input"> 
              <span class="input-label">Email</span> 
              <input ng-model="newUser.email" type="text"> 
            </label> 

            <button class="button button-full button-positive" ng-click="createContact(newUser)">
              Create
            </button> 

          </div> 
        </ion-content> 

      </ion-modal-view> 
    </script> 

  </body>
</html>

【CSS 代码】

body { 
  cursor: url('http://www.runoob.com/try/demo_source/finger.png'), auto;
}

【JavaScript 代码】

angular.module('ionicApp', ['ionic'])
.controller('AppCtrl', function($scope, $ionicModal) { 
  $scope.contacts = [ 
    { name: 'Gordon Freeman' }, 
    { name: 'Barney Calhoun' }, 
    { name: 'Lamarr the Headcrab' }, 
  ]; 
  $ionicModal.fromTemplateUrl('templates/modal.html', { 
    scope: $scope 
  }).then(function(modal) { 
    $scope.modal = modal; 
  }); 
  $scope.createContact = function(u) { 
    $scope.contacts.push({ name: u.firstName + ' ' + u.lastName }); 
    $scope.modal.hide(); 
  };
});

尝试一下 »

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,417评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,921评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,850评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,945评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,069评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,188评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,239评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,994评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,409评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,735评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,898评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,578评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,205评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,916评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,156评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,722评论 2 363
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,781评论 2 351

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,068评论 4 62
  • 前言的前言 唐巧前辈在微信公众号「iOSDevTips」以及其博客上推送了我的文章后,我的 Github 各项指标...
    VincentHK阅读 5,354评论 3 44
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,907评论 25 707
  • 如果你现在人生低迷,工作生活不如意,不妨看一下推荐的这个电影《怦然心动的人生整理法》。如果你现在春风得意,则不必留...
    快乐平行线阅读 442评论 1 1
  • 是不是开始写文字,就对这种种节日敏感了起来的,无论是传统的,舶来的,我都想应个景似的,对自己有个交待。 节日快乐。...
    湍河故事阅读 477评论 1 2