Skip to content

🚀 boilerplate for ionic4 with CI based on travis and fastlane. doc and example are provided

License

Notifications You must be signed in to change notification settings

pengkobe/ionic4-boilerplate

Repository files navigation

ionic4-boilerplate

build status David deps

boilerplate for ionic4
migrate and upgrade from : https://github.com/pengkobe/ionic-boilerplate

notes: Please ignore the CI build error status. it mainly caused by ios 2-factor authentication.

使用

git clone https://github.com/pengkobe/ionic4-boilerplate
cd ionic4-boilerplate
npm install
# git commit tool
npm install -g commitizen
commitizen init cz-conventional-changelog --save --save-exact

支持项

  • 运行环境介绍
  • 开发文档
    • 开发流程与规范
      • git
      • 测试
      • 代码规范
      • 工具集成
    • 环境搭建
      • Ionic
      • IOS
      • Android
    • 部署
      • travis
      • jenkins
      • fastlane
      • docker
  • 版本更新( apk )
  • 支持多语言[中/英]
  • http
    • http-interceptor
    • rebirth-http
  • 本地存储
    • rebirth-storage
  • 钩子( hooks )
  • 支持主目录相对定位
  • tslint 与 scsslint
  • 定义好目录结构
  • 集成 echarts
  • 去除开机白屏等待
  • 物理返回键双击退出
  • 错误上报
  • ngrx
    • TODO Demo
  • 主题切换示例
  • 常用组件
    • 二维码扫描
    • 日历组件
    • 动态表单
  • PWA
  • Cordova 插件说明与示例
    • 断网检测
    • 本地通知
    • 远程推送
  • 用户行为统计
  • 技巧与工具分享

运行环境介绍

本脚手架构建环境为( base on command: ionic info):

Android

Ionic:
   ionic (Ionic CLI)             : 4.12.0
   Ionic Framework               : @ionic/angular 4.3.1
   @angular-devkit/build-angular : 0.12.4
   @angular-devkit/schematics    : 7.2.4
   @angular/cli                  : 7.2.4
   @ionic/angular-toolkit        : 1.4.1

Cordova:

   cordova (Cordova CLI) : not installed
   Cordova Platforms     : not available
   Cordova Plugins       : cordova-plugin-ionic-keyboard 2.1.3, cordova-plugin-ionic-webview 2.2.0, (and 21 other plugins)

System:

   Android SDK Tools : 26.1.1
   NodeJS            : v8.9.0
   npm               : 5.5.1
   OS                : Windows 10

IOS

Ionic:

   ionic (Ionic CLI)             : 4.12.0
   Ionic Framework               : @ionic/angular 4.3.1
   @angular-devkit/build-angular : 0.12.4
   @angular-devkit/schematics    : 7.2.4
   @angular/cli                  : 7.2.4
   @ionic/angular-toolkit        : 1.4.1

Cordova:

   cordova (Cordova CLI) : 8.0.0
   Cordova Platforms     : ios 4.5.5
   Cordova Plugins       : cordova-plugin-ionic-keyboard 2.1.3, cordova-plugin-ionic-webview 2.3.1, (and 19 other plugins)

System:

   ios-deploy : 1.9.1
   ios-sim    : 5.0.3
   NodeJS     : v8.9.0
   npm        : 5.5.1
   OS         : macOS Mojave
   Xcode      : Xcode 10.1 Build version 10B61

开发文档

版本更新

支持 APK 更新与线上代码热更新
see: version-update

支持多语言[中/英]

基于 ngx-translate
see:https://github.com/ngx-translate/core

版本需要与 angular 对应的版本相匹配

npm install @ngx-translate/[email protected] --save
npm install @ngx-translate/[email protected] --save

http

http interceptor

对服务端返回码做全局处理,参见代码 http.interceptor.service.ts

rebirth-http

基于 rebirth-http 进行开发,可以大大节省开发工作量和代码维护难度。

本地存储

  • 结合 rebirth-storage 实现,支持了 localstorage 和内存两种方式
  • 使用 @ionic/storage,尽量不使用 localstorage,系统清内存时会被删掉

钩子

新版仍然可以使用,但是已经废弃了

位于文件夹 hooks 下, 可以写各个声明周期的钩子,目前引进的钩子有

  • 010_update_config, 根据 package.json 中的版本号更新 config.xml

支持主目录相对定位

通过在 tsconfig.json 中增加以下配置可以实现目录相对定位

  "baseUrl": "./src/",
    "paths": {
      "@app/env": ["environments/environment"],
      "@components/*": ["app/components/*"],
      "@services/*": ["app/services/*"],
      "@modals/*": ["app/modals/*"],
      "@directives/*": ["app/directives/*"],
      "@pipes/*": ["app/pipes/*"],
      "@app/*": ["app/*"],
      "@root/*": ["./*"],
      "echarts": ["../node_modules/echarts/dist/echarts.min.js"]
    }

tslint 与 scsslint

详情参见项目目录下 tslint.json.scss-lint.yml

定义好目录结构

按照功能模块职能进行区分,增加 share 与 core 等文件夹存放公有的模块和服务。

集成 echarts

脚手架已集成 echarts,教程可以参见 Integrate-ECharts-into-an-Ionic-2-app

去除开机白屏等待

在 config.xml 中替换 Splash Screen 相关配置为如下:

<preference name="FadeSplashScreenDuration" value="300" />
<preference name="SplashShowOnlyFirstTime" value="false" />
<preference name="SplashScreen" value="screen" />
<preference name="SplashScreenDelay" value="3000" />
<preference name="AutoHideSplashScreen" value="false" />
<preference name="FadeSplashScreen" value="false" />
<preference name="ShowSplashScreen" value="true" />

物理返回键双击退出

详情参见源代码下 src/app/app.component.ts 下方法 registerBackButtonAction

错误上报

基于 raven-js 上报错误信息至第三方平台。
文档地址:https://docs.sentry.io/clients/javascript/

npm install raven-js --save

ngrx

脚手架已集成 ngrx, 本脚手架 TODO Demo 即基于 ngrx 进行开发

主题切换示例

参见代码示例

常用功能

本脚手架提供了下述常用功能 Demo

  • 二维码扫描
  • 日历
  • 动态表单

PWA

集成教程可以参见:
https://www.joshmorony.com/create-a-pwa-with-angular-service-workers-in-ionic-4/
需要注意的是,ionic4 目前是基于 Angular6 进行开发,所以安装时需要指定之前的版本

ng add @angular/[email protected] --project app

可以参见 issue: ng add @angular/pwa doesn't work correctly in angular-cli 6.2.5 (Maximum call stack size exceeded)

Cordova 插件说明与示例

脚手架使用到的 Cordova 插件列表
see: cordova-plugin

用户行为统计

技巧与工具

see: tools

License

MIT@yipeng.info