Skip to content

ionic3 使用懒加载、极光推送、热更新、注册安卓物理返回键、安卓连线0.4px实现, http拦截器, 解决 ios 不能自动播放和禁止播放自动进入全屏

mzl1988/LlgApp

Repository files navigation

注意

  • demo 仅用于学习。里面用了第三方 api 请不要进行商业使用,后果自负!

可预览android版本apk

点击下载apk

点击下载兼容版本apk

电影

电台

阅读

video 组件

#LlgApp

Ionic 2 专注于以标准的 HTML 、 CSS 和 JavaScript 来构建移动站点,并可以通过 Cordova 打包成移动 App,只需编写一次代码,就可以分别部署到 iOS 、Android 等多种移动平台上。Ionic 2 与一代相比有较大的变化,基于最新的 Angular 2 (Angular 2 比Angular 1 快5到10倍),使用 TypeScript进行开发

安装Ionic2

  • npm uninstall -g ionic 如果之前安装过 Ionic 2 的 beta 版本,需要先卸载掉
  • npm install -g ionic@latest
  • ionic -version 查看版本号

安装Cordova

  • npm install -g cordova
  • cordova -version 查看版本号

安装JDK

安装Android SDK

创建项目

  • ionic start 项目名称 模板名称 --v2 如:ionic start demo tabs --v2

在浏览器中运行

  • npm config set sass_binary_site=https://npm.taobao.org/mirrors/node-sass/
  • npm install
  • cp ./src/providers/_Constants.ts ./src/providers/Constants.ts
  • ionic serve 或 ionic serve --address 192.168.10.113 --port 6228 --livereload-port 35600 --dev-logger-port 53600

Navigation

Navigation控制App内不同的页面间进行转换。Ionic的Navigation遵循各原生平台的导航原则。Navigation是在ion-nav组件内进行处理的,像一个简单的栈,页面被push或被pop,就可以实现向前导航或历史栈的后退导航。

主题化

Ionic App支持主题风格。要改变主题,只需要调整src/theme/variables.scss文件中的$colors

安装cordova插件的时候用ionic cordova plugin add ...的方式添加,这样会在package.json中添加这个插件的条目,如果有人clone了你的项目想在本地运行,可以用ionic state restore它会根据cordovaPlugins条目安装对应的插件。如果直接用cordova plugin add 安装则不会更新package.json。 删除用 ionic cordova plugin remove

兼容android4.0

  • cordova-plugin-crosswalk-webview

platform 平台

  • ionic cordova platform add android

移除平台

  • ionic cordova platform remove android

emulate 将Ionic项目部署到模拟器或仿真器上

emulate命令将App部署到特定的平台设备上。你也可以通过在特定的模拟器上添加--livereload选项运行live reload。live reload功能类似ionic serve,但是不是使用标准的浏览器来开发和调试,编译后的hybrid应用本身会监控任何文件改变并在需要的时候重新载入App。这降低了针对小改动需要频繁重新编译App的需求。然而任何插件的改变将导致完全的重新编译。为使live reload能够正常工作,开发机和模拟器必须在一个相同的本地网络中,并且设备必须支持web sockets。

  • ionic cordova emulate android --address 192.168.10.113
  • ionic cordova emulate android --livereload --address 192.168.10.113 --port 6228 --livereload-port 35700 --dev-logger-port 53700

run 在连接的设备上运行Ionic项目

run命令将应用部署到指定的设备上。你可以通过添加--livereload选项在指定的平台设备上运行live reload。live reload功能类似ionic serve,但是不是使用标准的浏览器来开发和调试,编译后的hybrid应用本身会监控任何文件改变并在需要的时候重新载入App。这降低了针对小改动需要频繁重新编译App的需求。然而任何插件的改变将导致完全的重新编译。为使live reload能够正常工作,开发机和模拟器必须在一个相同的本地网络中,并且设备必须支持web sockets。

ionic cordova run android --livereload ionic cordova run android --address 192.168.10.113 --port 6228 --livereload

制作签名文件(.keystore文件)

keytool -genkey -v -keystore LlgApp.keystore -alias LlgApp -keyalg RSA -validity 10000

build

  • 打包debug调试版(生成的apk就是debug调试版本) ionic cordova build android --prod
  • 打包release发布版(release版本是必须有签名才能在手机上运行) ionic cordova build android --prod --release --buildConfig

info

  • ionic info 列出用户的Ionic运行环境信息

远程调试——VS Code插件

VS Code有一个专用的插件(Cordova Tools)来调试Cordova程序。这个插件在设备和调试器直接建立桥接,允许你在编辑器中直接设置断点。

远程调试——Android和Chrome

Chrome DevTools开发者工具是调试应用的有力工具。当你使用ionic serve命令在浏览器中运行应用的时候,DevTools可以用来检查元素,查看console日志,分析应用或其他更多功能。 DevTools除了可以在浏览器中调试应用,还可以用来远程调试物理设备甚至Genymotion模拟器中的应用。首先,我们需要安装adb。安装后一旦设备连接上,或Android模拟器运行起来的时候,你可以运行下面的命令来查看设备列表: $ adb devices 然后在Chrome中打开chrome://inspect/#devices来查看Android设备。注意,也许需要改变设备的设置来允许USB调试。注意你可以使用Chrome来调试应用,就像在浏览器中那样!

使用typings

  • typings search echarts
  • typings install dt~echarts --global --save

ionic2 css-utilities

命令行工具自动修改应用图标及添加启动画面

  1. 在项目的根目录下创建resources文件夹。

  2. 在文件夹中都放入icon.png(应用图标,最小1024×1024px,不带圆角),splash.png(启动屏幕,最小2732×2732px,中间区域1200x1200px)(可以是 png、psd、ai)

  3. 在cmd中进入项目所在文件夹执行:ionic cordova resources .执行该命令后,会自动在resources文件夹下创建已添加的平台名称的文件夹,如:android,其 中会自动将图片进行缩放、裁剪,生成不同分辨率的图片,并在config.xml中添加相应内容。

    也可分开执行:

    • ionic cordova resources --icon, -i 生成图标资源
    • ionic cordova resources --splash, -s 生成启动画面资源
    • ionic cordova resources --force, -f 强制资源再生
  4. 要禁用此功能并始终覆盖生成的图像,请使用--force

极光推送

Ionic2/3 热更新

statusBar.overlaysWebView(true); android 经常不生效

在MainActivity.java(platforms/android/src/../../MainActivity.java)中导入依赖包:

import android.os.Build;
import android.view.View;

在MainActivity.java中的super.onCreate() 函数后添加如下代码:

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
   getWindow().getDecorView().setSystemUiVisibility(
       View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN |
       View.SYSTEM_UI_FLAG_LAYOUT_STABLE);
}

生命周期

  • ionViewLoaded 页面加载完毕触发。该事件发生在页面被创建成 DOM 的时候,且仅仅执行一次。如果页面被缓存(Ionic默认是缓存的)就不会再次触发该事件。该事件中可以放置初始化页面的一些事件。
  • ionViewWillEnter 即将进入一个页面变成当前激活页面的时候执行的事件。
  • ionViewDidEnter 进入了一个页面且变成了当前的激活页面,该事件不管是第一次进入还是缓存后进入都将执行。
  • ionViewWillLeave 将要离开了该页面之后变成了不是当前激活页面的时候执行的事件。
  • ionViewDidLeave 在页面完成了离开该页面并变成了不是当前激活页面的时候执行的事件。
  • ionViewWillUnload 在页面销毁和页面中有元素移除之前执行的事件。
  • ionViewDidUnload 在页面销毁和页面中有元素移除之后执行的事件。

About

ionic3 使用懒加载、极光推送、热更新、注册安卓物理返回键、安卓连线0.4px实现, http拦截器, 解决 ios 不能自动播放和禁止播放自动进入全屏

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published