`

Ionic 2 添加页面

 
阅读更多

现在我们已经基本知道了Ionic2 app的布局,接下来我们来走一遍在我们的app里创建和导航页面的过程。

先看看src/app/app.html, 接近底部的地方有如下内容:

<ion-nav id="nav" [root]="rootPage" #content swipeBackEnabled="false"></ion-nav>

注意[root]属性绑定。设置了ion-nav组件的根页面或是第一个基本页面。当加载ion-nav是,rootPage变量引用的就是根页面。

在 src/app/app.component.ts 里, MyApp 组件在它的构造器中定义了他。:

...
import {HelloIonicPage} from '../pages/hello-ionic/hello-ionic';
...

export class MyApp {
  ...

  // make HelloIonicPage the root (or first) page
  rootPage: any = HelloIonicPage;
  pages: Array<{title: string, component: any}>;

    constructor(
      private platform: Platform,
      private menu: MenuController
    ) {
    ...
  }

  ...
}

我们可以看到rootPage设置为HelloIonicPage,因此HelloIonicPage将会是nav controller中加载的第一个页面。让我们来看一下。

创建页面

接下来我们看看导入的HelloIonicPage 。在 src/pages/hello-ionic/目录下,打开hello-ionic.ts文件。

你可能注意到每个页面有一个目录。在每个目录中还有另外两个同名的.html 和 .scss 文件。例如,在hello-ionic/里面有hello-ionic.ts, hello-ionic.html 和 hello-ionic.scss三个文件。尽管这不是必须的模式,但是这对组织代码很有帮助。

下面,我们看到HelloIonicPage类。这将创建一个页面,提供一个包含所有Ionic指令的Angular组件,加载使用Ionic的导航系统。请注意,因为页面是动态加载,他们没有选择器:

import {Component} from '@angular/core';

@Component({
  templateUrl: 'build/pages/hello-ionic/hello-ionic.html'
})
export class HelloIonicPage {}

所有页面都有一个类,和一个关联的模板的编译。 我们看看 src/pages/hello-ionic/hello-ionic.html - 这个页面的模版文件:

<ion-header>
  <ion-navbar>
    <button menuToggle>
      <ion-icon name="menu"></ion-icon>
    </button>
    <ion-title>Hello Ionic</ion-title>
  </ion-navbar>
</ion-header>


<ion-content padding class="getting-started">

  <h3>Welcome to your first Ionic app!</h3>

  <p>
    This starter project is our way of helping you get a functional app running in record time.
  </p>
  <p>
    Follow along on the tutorial section of the Ionic docs!
  </p>
  <p>
    <button primary menuToggle>Toggle Menu</button>
  </p>

</ion-content>

<ion-navbar>是这个页面的导航条模版。当我们导航到这个页面,导航条上的按钮和标题作为页面的一部分一起过渡过来。
余下的模版是标准的Ionic代码设置内容区域,打印欢迎信息。

创建附加页面

创建附加页面,我们只需要确保正确设置标题和其他我们希望导航条显示的东西。
我们再来看看src/pages/list/list.ts里面的内容,你会发现定义了一个新的页面:

import {Component} from "@angular/core";
import {NavController, NavParams} from 'ionic-angular';
import {ItemDetailsPage} from '../item-details/item-details';


@Component({
  templateUrl: 'build/pages/list/list.html'
})
export class ListPage {
  selectedItem: any;
  icons: string[];
  items: Array<{title: string, note: string, icon: string}>;

  constructor(private navCtrl: NavController, navParams: NavParams) {
    // If we navigated to this page, we will have an item available as a nav param
    this.selectedItem = navParams.get('item');

    this.icons = ['flask', 'wifi', 'beer', 'football', 'basketball', 'paper-plane',
    'american-football', 'boat', 'bluetooth', 'build'];

    this.items = [];
    for(let i = 1; i < 11; i++) {
      this.items.push({
        title: 'Item ' + i,
        note: 'This is item #' + i,
        icon: this.icons[Math.floor(Math.random() * this.icons.length)]
      });
    }
  }

  itemTapped(event, item) {
     this.navCtrl.push(ItemDetailsPage, {
       item: item
     });
  }
}

这个页面创建了一个包含多个数据项的列表页。总之,这个页面和前面的HelloIonicPage 很相似。

0
1
分享到:
评论

相关推荐

    ionic2 new demo

    2. **页面结构**:`Ionic2`应用由多个页面(Page)组成,每个页面都包含一个组件。在本示例中,你可以看到如何定义和使用自定义页面,例如,创建一个包含下拉框和输入框的新组件。 3. **UI组件**: - **下拉框...

    Ionic创建页面以及页面之间跳转、页面添加返回按钮、新增底部页面示例代码.zip

    在本文中,我们将深入探讨如何使用Ionic框架创建页面、实现页面间的跳转,以及如何在页面上添加返回按钮和创建底部导航栏。Ionic是一个流行的开源框架,它基于Angular,用于构建跨平台的移动应用和 Progressive Web ...

    ionic2入门学习PPT

    ### ionic2入门知识点概述 本篇文档针对的是Ionic2框架的初学者,旨在通过简明扼要的方式介绍Ionic2的基础知识与环境搭建流程。Ionic2是一个强大的开源UI框架,用于构建高性能的混合移动应用程序。它基于AngularJS...

    ionic2 demo

    6. **移动应用开发**:Ionic2 Demo项目展示了移动应用开发的基本流程,包括创建页面、处理用户交互、管理状态、实现导航等。开发者可以通过分析该项目学习如何在移动设备上实现常见功能。 7. **组件化**:Ionic2...

    ionic capacitor调用原生本地代码 切换页面

    ionic capacitor调用原生本地代码 切换页面

    Building-Mobile-Apps-with-Ionic-2

    - **推送和弹出页面**:Ionic 2提供了一个导航控制器来管理页面堆栈,允许开发者通过`push`和`pop`操作来控制页面的显示和隐藏。 - **基本导航**:使用`NavController`来控制页面的切换。 - **传递数据**:通过参数...

    EXPERT-Building-Mobile-Apps-with-Ionic-2

    - **创建页面、组件、指令、管道和服务**:这些是Angular的核心概念,也是Ionic 2应用程序的基础构建块。例如,页面代表了一个特定的视图,而组件则封装了视图及其相关行为。 #### 模板与样式 - **模板语法**:...

    ionic2中使用echarts3创建图表

    在本文中,我们将深入探讨如何在Ionic 2框架中集成并使用ECharts 3库创建图表。ECharts是一个由百度开发的开源JavaScript可视化库,它提供了丰富的图表类型和灵活的数据可视化解决方案。而Ionic 2是基于Angular 2的...

    ionic angular capacitor项目展示控件使用,页面跳转,网络请求封装

    在`Ionic`应用中,每个页面都是一个单独的Angular组件。创建新页面通常涉及以下步骤: - 创建一个新的Angular组件,如`ng generate component my-page`。 - 在`app-routing.module.ts`中定义路由,将新页面与URL路径...

    ionic应用实用模板

    - **Tabs**: 在Ionic中,tabs是一种常见的导航模式,常用于多页面应用,让用户可以轻松在多个主视图之间切换。每个tab代表一个页面或一组相关的页面,通常位于屏幕底部。 - **自定义与优化**: 基于默认tabs模板的...

    04 ionic新增tab切换页面 去掉二级页面tabs菜单,修改返回按钮-avi.rar

    在本教程中,我们将深入探讨如何在Ionic框架中创建一个新的tab切换页面,并针对特定场景去掉二级页面的tabs菜单,同时修改返回按钮的行为。Ionic是一款基于Angular的开源移动应用框架,它提供了一套丰富的组件和工具...

    ionic购物商城demo源码

    2. **路由与导航**:在购物商城应用中,用户需要在商品列表、购物车、订单详情等多个页面间进行切换。Ionic提供了NavController,通过定义路由规则,可以轻松实现页面间的导航。 3. **数据管理**:商品信息、用户...

    ionic2中使用echarts3

    在本文中,我们将深入探讨如何在Ionic 2项目中集成并使用ECharts 3图表库。ECharts是一款基于JavaScript的数据可视化库,它提供了丰富的图表类型,适用于多种数据展示需求。而Ionic 2则是一个强大的移动应用框架,...

    完整的Ionic项目实例

    2. 添加平台:`ionic platform add android` 或 `ionic platform add ios` 3. 运行应用:`ionic serve`(本地开发)或`ionic run android` / `ionic run ios`(真机或模拟器) **6. 实现功能** 由于没有具体的项目...

    ionic succinctly快速入门

    Ionic CLI是一个非常强大的工具,它允许开发者通过简单的命令来创建项目、添加页面和组件,以及打包和测试应用程序。本书介绍了如何安装Ionic-Angular,并创建一个新的Ionic项目。创建项目后,可以利用Live Reload...

    ionic-datepicker-oysq

    在使用"ionic-datepicker-oysq"时,首先你需要将这个插件添加到你的项目中。这通常涉及到下载压缩包,然后将其解压到你的项目目录下。根据提供的描述,解压后的文件中应该有一个名为`date.html`的文件,这很可能是...

    ionic2transparentbar在ionic2中实现的一个透明条DEMO

    在本文中,我们将深入探讨如何在Ionic 2框架中实现一个透明导航条,这主要基于提供的标题"ionic2transparentbar在ionic2中实现的一个透明条DEMO"以及描述中的"ionic2-transparent-bar"项目。我们将重点讲解这个DEMO...

    使用Ionic2制作移动APP

    一个标准的Ionic2应用项目结构包括了多种文件类型和目录,例如组件(components)、页面(pages)、服务(services)以及资源文件(assets)。组件通常包含模板(template)、样式(style)和脚本(script)三个主要...

    ionic 案例源码 Mallzee

    - **Ionic Router**:基于Angular Router,用于处理页面间的跳转。通过定义路由配置,可以实现页面之间的动态导航。 - **NavController**:提供页面栈管理,支持前进、后退、弹出、插入页面等操作。 5. **服务和...

    ionic3仿京东商城源码

    通过分析这个源码,开发者可以学习到如何利用Ionic3的特性,如离子组件(如 ion-list, ion-item, ion-header 等)、Angular服务(如 HttpClient 用于网络请求,Angular Router 用于页面导航)以及TypeScript的面向...

Global site tag (gtag.js) - Google Analytics