zoukankan      html  css  js  c++  java
  • Ionic3,组件的使用(四)

    说明

      因为同样是作为 Ionic3 小白,所以很多东西都是自己摸索出来的,可能有很多不合理的地方,请多多指正。

    效果图

    细节说明

      一:组件、页面均采用 懒加载;

      二:页面的头部标题栏,采用了组件化的方式,用来提高代码的公用率;

      三:页面布局采用的是 ion-grid、ion-list(会做一个总结);

      四:通过使用了一些 angularjs 语法,ngFor、ngStyle、通过import Events 实现数据的回调、ngZone进行页面的重构、数据的双向绑定、@inpput()、@ViewChild()

    创建组件

      执行命令:ionic g component 组件名称

        命令执行完成后,如图生成三个文件(其中.module.ts文件是我自己加的,用来实现懒加载),第一次创建还会有一个componen.module.ts文件。

      

        组件调用时的名称,在 app-header.ts 文件中进行规定:selector 规定了调用时,元素的名称<app-header></app-header>

        

        组建中关于 app-header.module.ts 懒加载的声明:

    import { NgModule } from "../../../node_modules/@angular/core";
    import { AppHeaderComponent } from "./app-header";
    import { IonicPageModule } from "../../../node_modules/ionic-angular";
    
    @NgModule({
        declarations:[
            AppHeaderComponent
        ],
        imports:[
            IonicPageModule.forChild(AppHeaderComponent)
        ]
    })
    export class AppHeaderComponentModule{
    
    }
    View Code

        关于 components.module.ts 文件中的声明:

    import { NgModule } from '@angular/core';
    import { AppHeaderComponent } from './app-header/app-header';
    import { CommonModule } from '../../node_modules/@angular/common';
    import { IonicModule } from '../../node_modules/ionic-angular';
    
    @NgModule({
        declarations: [AppHeaderComponent],
        imports: [
            CommonModule,
            IonicModule
        ],
        exports: [AppHeaderComponent]
    })
    export class ComponentsModule {}
    View Code

        在相关页面 .ts 文件中导入插件:(我这里是在 finder.html 页面中进行的引用)

    import { IonicPageModule } from 'ionic-angular';
    import { FinderPage } from './finder';
    import { NgModule } from "@angular/core";
    import { ComponentsModule } from '../../../components/components.module';
    
    @NgModule({
        declarations:[
            FinderPage
        ],
        imports:[
            IonicPageModule.forChild(FinderPage),
            ComponentsModule
        ]
    })
    
    export class FinderPageModule{
    
    }
    View Code

        在相关的页面中引用插件:其中关于 search-show、title属性的定义意义会作另讲,详细说明。

  • 相关阅读:
    准备 LVM Volume Provider
    掌握 cinder-scheduler 调度逻辑
    Cinder 组件详解
    掌握 Cinder 的设计思想
    理解 Cinder 架构
    1 张图秒懂 Nova 16 种操作
    计算节点宕机了怎么办?- 每天5分钟玩转 OpenStack(43)
    Live Migrate 操作
    Resize Instance 操作详解
    关于Linux的10个核心面试问题与答案
  • 原文地址:https://www.cnblogs.com/mysouler/p/9458178.html
Copyright © 2011-2022 走看看