Ionic中(弹出式窗口)的$ionicModal使用方法

简介:

Ionic中[弹出式窗口]有两种(如下图所示), i o n i c M o d a l ionicPopup;

$ionicModal是完整的页面;

$ionicPopup是(Dialog)对话框样式的,直接用JavaScript设定对话框的一些参数,通常用于通知消息、确认等作用;

 

本文主要介绍IonicModal的使用方法

中文文档:http://ionicframework.net/docs/api/service/$ionicModal/

英文文档:http://ionicframework.com/docs/api/service/$ionicModal/

$ionicModal(中文翻译为‘模型’,感觉还是直接称为用Modal好一点。)

模型是一个内容面板,可以临时越过用户的主视图。通常用于选择或编辑一个项。注意,你需要把模型的内容放入一个带有modal类的div内。

举个例子,啥是Modal?:

登录或者注册页面的用户协议(图1),点击“用户协议”之后,会弹出用户协议具体内容(图2),这个地方就可以使用Modal来实现。图3中展示了Application运行起来之后,登录页面的源代码(这些都是ionic自己生成的),忽略其他信息,只看我标出来的红色1和红色2,当前红色2的元素是hide,当我们点击“用户协议”之后,红色2就会从“hide”变成“actived”,这时候我们就看到了图2的内容了。

图1 登录界面用户协议

图2 用户协议具体内容(Modal)

图3 查看网页源代码

如何实现Modal?

首先要有自己Modal的html代码,注意,你需要把模型的内容放入一个带有modal类的div内。

复制代码
<script id="my-modal.html" type="text/ng-template">
  <div class="modal">
    <ion-header-bar>
      <h1 class="title">我的模型标题</h1>
    </ion-header-bar>
    <ion-content>
      Hello!
    </ion-content>
  </div>
</script>
复制代码

然后写自己的js代码(其实就是AngularJS代码)

这部分需要注意以下几点:

(1)不要忘了function的参数$ionicModal,否则会报错(用浏览器的调试工具F12可以看到)

(2)使用fromTemplateUrl将HTML代码中script(根据id)在HTML页面生成自己的Modal(也就是说,在打开页面的时候,是没有图3中的红色2 div的,当调用了fromTemplateUrl之后,才会生成这个div,而且每调用一次就会生成一个红色2 div哦,所以写代码的时候要把逻辑设计好,注意及时remove()。);

(3)openModal和closeModal函数很容易理解,这个估计是Modal最常用的方法;

(4)可以通过 s c o p e . on来进行更丰富的操作(当然,不用 s c o p e . on也可以进行丰富的操作。);

复制代码
 1 angular.module('testApp', ['ionic'])
 2 .controller('MyController', function($scope, $ionicModal) {
 3   $ionicModal.fromTemplateUrl('modal.html', {
 4     scope: $scope,
 5     animation: 'slide-in-up'
 6   }).then(function(modal) {
 7     $scope.modal = modal;
 8   });
 9   $scope.openModal = function() {
10     $scope.modal.show();
11   };
12   $scope.closeModal = function() {
13     $scope.modal.hide();
14   };
15   //当我们用完模型时,清除它!
16   $scope.$on('$destroy', function() {
17     $scope.modal.remove();
18   });
19   // 当隐藏模型时执行动作
20   $scope.$on('modal.hide', function() {
21     // 执行动作
22   });
23   // 当移动模型时执行动作
24   $scope.$on('modal.removed', function() {
25     // 执行动作
26   });
27 });
复制代码

详细说说创建的方法

可以使用字符串或者一个URL:

fromTemplate(templateString, options)

templateString  是字符串类型,存储的是模型的内容;

options是一个对象,存储的是ionicModal#initialize方法的选项;

返回一个Modal控制器实例;

一个options对象具有一下属性:

  • {object=} 范围 子类的范围。默认:创建一个$rootScope子类。
  • {string=} 动画 带有显示或隐藏的动画。默认:'slide-in-up'
  • {boolean=} 第一个输入框获取焦点 当显示时,模型的第一个输入元素是否自动获取焦点。默认:false。
  • {boolean=}backdropClickToClose` 点击背景时是否关闭模型。默认:true。

fromTemplateUrl(templateUrl, options)

templateUrl 是字符串类型,指向待加载模版的URL;

options与上边的一样;

返回一个promise对象,指向一个Modal控制器实例;

 更直观一点的使用url创建:

复制代码
1 $ionicModal.fromTemplateUrl('templates/hello.html', {// modal窗口选项
2     scope: $scope,
3     animation: 'silde-in-up'
4 }).then(function (modal) {
5      $scope.modal = modal;
6 })
复制代码

templates目录下hello.html内容如下:

复制代码
1 <ion-modal-view>
2     <ion-header-bar class="bar-energized">
3         <h1 class="title">标题</h1>
4     </ion-header-bar>
5     <ion-content>
6         Hello~~~~
7     </ion-content>
8 </ion-modal-view>
复制代码
相关文章
electron设置window系统托盘
electron设置window系统托盘
167 0
|
3月前
|
UED 开发者
Flutter笔记:Widgets Easier组件库(13)- 使用底部弹窗
Flutter笔记:Widgets Easier组件库(13)- 使用底部弹窗
59 2
|
4月前
|
JavaScript
【vue】el-dialog 内的tinymce弹窗被遮挡的解决办法 及 tinymce打开弹出菜单后直接关闭对话组件,导致该弹出菜单残留
【vue】el-dialog 内的tinymce弹窗被遮挡的解决办法 及 tinymce打开弹出菜单后直接关闭对话组件,导致该弹出菜单残留
314 6
|
4月前
|
前端开发
【UI】 elementui的dialog弹窗打开时CSS的BUG | 滚动条消失bug
【UI】 elementui的dialog弹窗打开时CSS的BUG | 滚动条消失bug
147 0
|
12月前
|
C++
美化----VS Code 文件小图标插件 “VScode icon”
美化----VS Code 文件小图标插件 “VScode icon”
197 0
|
Java
Java开发GUI之Dialog弹出窗口
Java开发GUI之Dialog弹出窗口
194 0
GTK 3.0弹出窗口及设置背景图片的代码
GTK 3.0弹出窗口及设置背景图片的代码
232 0
|
容器
Flutter 底部弹窗ModelBottomSheet详解
本篇介绍了三种 ModalBottomSheet 的方式,实际开发过程中,还可以根据需要,利用 ModalBottomSheet的 builder 方法构建自定义的底部弹窗,满足业务需要。
1218 0
Flutter 底部弹窗ModelBottomSheet详解
|
存储
flutter使用 RfFlutter 来显示对话框
RfFlutter 具有看起来不错的基本警报,并且可以轻松使用。我们将设置一个带有 HomeView 无状态小部件的基本应用程序。我将使用功能性小部件,这样我就不会编写太多代码。您可以通过定义整个类来使用普通的无状态小部件。我们将让我们的应用程序带有一个简单的 HomeView 小部件。我们将在整个教程中使用的中心有一个按钮。
197 0