ionic2(仿单糖app)-03项目模块化

设计结构如下

模块化设计

其中 component.module 是公共组件的模块。虚线的base.module 是暂时没有实现的模块,里面应该包含所有项目都能通用的一些服务、组件等。

代码结构如下

代码模块结构
根模块内容
import { NgModule, ErrorHandler } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { IonicApp, IonicModule, IonicErrorHandler } from 'ionic-angular';
import {HttpModule} from '@angular/http';

import { MyApp } from './app.component';
import { TabsPage } from '../pages/tabs/tabs';

import { MineModule } from '../pages/mine/mine.module';
import { HomeModule } from '../pages/home/home.module';
import { ClassifyModule } from '../pages/classify/classify.module';
import { ShoppingModule } from '../pages/shopping/shopping.module';

import { StatusBar } from '@ionic-native/status-bar';
import { SplashScreen } from '@ionic-native/splash-screen';
import { Network } from '@ionic-native/network';
import { IonicStorageModule } from '@ionic/storage';
import { HttpService } from '../providers/HttpService';
import { NativeServiceC } from '../providers/NativeServiceC';
import { GlobalData } from '../providers/GlobalData';

@NgModule({
  declarations: [
    MyApp,
    TabsPage
  ],
  imports: [
    BrowserModule,
    HttpModule,
    IonicModule.forRoot(MyApp,{
      mode:'ios', // android是"md" 统一为iOS平台样式
      backButtonText:'',
      tabsHideOnSubPages:true
    }),
    IonicStorageModule.forRoot(),
    //  自定义模块
    MineModule,
    HomeModule,
    ClassifyModule,
    ShoppingModule
  ],
  bootstrap: [IonicApp],
  entryComponents: [
    MyApp,
    TabsPage
  ],
  providers: [
    StatusBar,
    SplashScreen,
    Network,
    HttpService,
    NativeServiceC,
    GlobalData,
    {provide: ErrorHandler, useClass: IonicErrorHandler}
  ]
})
export class AppModule {}
  • declarations - 声明本模块中拥有的视图类。Angular 有三种视图类:组件、指令、管道。

  • exports 导出对外公开的组件、模块

  • imports 本模块声明的组件模板需要的类所在的其它模块

  • providers 本模块中包含的服务。

  • bootstrap 指定应用的主视图(称为根组件),它是所有其它视图的宿主。只有根模块才能设置bootstrap属性。

子模块内容
import {NgModule} from '@angular/core';
import {IonicPageModule} from 'ionic-angular';
import {HomePage} from './home';

// module
import {ComponentModule} from '../../component/component.module'

import { LoginService} from '../login/loginService'

@NgModule({
    imports: [
        IonicPageModule.forChild(HomePage),
        ComponentModule
    ],
    declarations: [HomePage],
    entryComponents: [],
    providers: [],
    exports: []
})
export class HomeModule {
}

和根模块的内容基本相同 较简单 其他模块一样

这样进行 模块化以后 每一个模块都只关心和自己相关的组件 服务等 层级管理 较为方便

其他

项目代码在码云上管理 更新中。。。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,084评论 19 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,111评论 25 709
  • 在补充作业的过程中,发现可能性真的很多。 比如在查找的“乡村旅游发展中医疗服方面的不足”的这个问题时,做了思维导图...
    江62阅读 1,405评论 0 0
  • 一千种人就有一千种活法,这句感悟是我经过两天的“品衣识人”课程得到的最大的收获,我从来不知道会有那样一群女人,在经...
    今天安好阅读 4,868评论 0 2
  • 不管这一天有多难过 记得认真卸妆洗脸冲澡 吹干头发 安安稳稳钻进被窝 床就像一个胶囊 时光咻一下 就带你到一个明亮...
    笃学青衿阅读 1,594评论 2 1

友情链接更多精彩内容