开始接入
Hippy 已经提供了完整的前终端范例,可以直接基于我们现有的范例开始 App 开发。
如果要在已有的 App 里整合 Hippy,那就请继续阅读下面的终端集成
章节。需要提醒的是,在 Hippy 体系下,终端开发转变为平台开发
,前端开发变成业务开发
,平台开发
提供通用的能力,供业务开发
完成实际交互,因此还要注意以后续的自定义章节
,这都需要进入起步
菜单下对应的终端章节。
终端集成
如果要接入 Hippy 到现有项目,请查看 iOS 或 Android 集成教程。
前端接入
Hippy 同时支持 React 和 Vue 两种语法,通过 @hippy/react 和 @hippy/vue 两个包提供实现。
但是从工程上我们依然称呼它们为
hippy-react
和hippy-vue
。
hippy-react
hippy-react 工程暂时只能通过手工配置初始化(后期会提供基于 yeoman 的脚手架),建议直接 clone 范例工程并基于它进行修改。
当然,也可以从头开始进行配置。
准备 hippy-react 运行时依赖
请使用 npm i
安装以下 npm 包,保证运行时正常。
包名 | 说明 |
---|---|
@hippy/react | hippy-react 运行时和渲染层 |
react | react 本体 |
regenerator-runtime | async/await 转换运行时 |
hippy-react 编译时依赖
以官方提供的 范例工程 范例工程为例,需要使用 npm i -D
准备好以下依赖,当然开发者可以根据需要自行选择:
必须的:
包名 | 说明 |
---|---|
@babel/plugin-proposal-class-properties | Babel 插件 - 支持仍在草案的 Class Properties |
@babel/preset-env | Babel 插件 - 根据所设置的环境选择 polyfill |
@babel/preset-react | Babel 插件 - 转译 JSX 到 JS |
@hippy/debug-server | Hippy 前终端调试服务 |
babel/core | Babel - 高版本 ES 转换为 ES6 和 ES5 的转译程序 |
babel-loader | Webpack 插件 - 加载 Babel 转译后的代码 |
unicode-loader | Webpack 插件 - Hippy 只支持 unicode 的代码 |
webpack | Webpack 打包程序 |
webpack-cli | Webpack 命令行 |
可选的:
包名 | 说明 |
---|---|
case-sensitive-paths-webpack-plugin | Webpack 插件,对 import 文件进行大小写检查 |
file-loader | 静态文件加载 |
url-loader | 静态文件以 Base64 形式加载 |
hippy-react 编译配置
配置全部放置于 scripts 目录下,其实只是 webpack 的配置文件,建议先阅读 webpack 官网内容,具备一定基础后再进行修改。
hippy-react 终端开发调试用编译配置
该配置展示了将 Hippy 运行于终端的最小化配置。
配置文件 | 说明 |
---|---|
hippy-webpack.dev.js | 调试用配置 |
终端线上包配置
线上包和开发调试用包主要有两个区别:
- 开启了 production 模式,去掉调试信息,关闭了
watch
(watch 模式下会监听文件变动并重新打包)。 - 终端内很可能不止运行一个 Hippy 业务,所以将共享的部分单独拆出来做成了
vendor
包,这样可以有效减少业务包体积,这里使用了 DllPlugin 和 DllReferencePlugin 来实现。需要说明的是生成的vendor
包正常情况下是不需要特别更新的,但是如果更新了也要注意一下向上兼容性,不要因为分包导致业务崩溃。
配置文件 | 说明 |
---|---|
vendor.js | vendor 包中需要包含的共享部分 |
hippy-webpack.ios.js | iOS 业务包配置 |
hippy-webpack.ios-vendor.js | iOS Vendor 包配置 |
hippy-webpack.android.js | Android 业务包配置 |
hippy-webpack.android-vendor.js | Android Vendor 包配置 |
如果仔细观察 webpack 配置,可以看出 iOS 和 Android 配置差不多,但因为 iOS 上受苹果政策影响只能使用 JavaScriptCore(以下简称 JSC)作为运行环境,而 JSC 是跟随 iOS 操作系统的,无法进行独立升级,低版本 iOS 带的 JSC 甚至无法完整支持 ES6,所以需要输出一份 ES5 版本的 JS 代码。而 Android 下可以使用可以独立升级的 X5 中的 V8 作为运行环境,就可以直接使用 ES6 代码了。ES6 代码不但运行更快,体积还会更小一些。
特别说明:JS 方面可以使用的功能其实受到 iOS 覆盖最低版本的影响,绝大多数功能可以通过
@babel/preset-env
自动安装 polyfill,但是部分特性不行,例如要使用 Proxy,就无法覆盖 iOS 10 以下版本。
hippy-react 入口文件
入口文件非常简单,只是从 hippy-react 里初始化一个 Hippy 实例。
import { Hippy } from '@hippy/react';
import App from './app';
new Hippy({
appName: 'Demo', // 终端分配的业务名称
entryPage: App, // 对应业务启动时的组件
slient: false, // 设置为 true 可以关闭框架日志输出
}).start();
hippy-react npm script
最后在 package.json 中补上几个快速的 npm 脚本就可以了,这里以 hippy:
开头做好了范例,这里顺道做了一个到 hippy-debug-server 的快速启动命令。
"scripts": {
"hippy:debug": "hippy-debug",
"hippy:dev": "webpack --config ./scripts/hippy-webpack.dev.js",
"hippy:vendor": "webpack --config ./scripts/hippy-webpack.ios-vendor.js --config ./scripts/hippy-webpack.android-vendor.js",
"hippy:build": "webpack --config ./scripts/hippy-webpack.ios.js --config ./scripts/hippy-webpack.android.js"
}
hippy-react 转 Web
请参考专门的 hippy-react 转 Web 章节。
hippy-vue
hippy-vue 相对简单很多,hippy-vue 只是 Vue 在终端上的渲染层,组件也基本和浏览器保持一致。可以通过 vue-cli 先创建一个 Web 项目,然后加上一些 hippy-vue 的内容就可以直接将网页渲染到终端了。
准备 hippy-vue 运行时依赖
请使用 npm i
安装以下 npm 包,保证运行时正常。
包名 | 说明 |
---|---|
@hippy/vue | hippy-vue 运行时核心 |
@hippy/vue-native-components | hippy-vue 的扩展终端组件 |
@hippy/vue-router | vue-router 在 hippy-vue 上的移植 |
hippy-vue 编译时依赖
以官方提供的 范例工程 范例工程为例,需要使用 npm i -D
准备好以下依赖,当然开发者可以根据需要自行选择:
必须的:
包名 | 说明 |
---|---|
@hippy/debug-server | Hippy 前终端调试服务 |
@hippy/vue-css-loader | hippy-vue 的 CSS 文本到 JS 语法树转换 |
unicode-loader | Webpack 插件 - Hippy 只支持 unicode 字符集 |
可选的:
包名 | 说明 |
---|---|
case-sensitive-paths-webpack-plugin | Webpack 插件,对 import 文件进行大小写检查 |
hippy-vue 编译配置
配置全部放置于 scripts 目录下,其实只是 webpack 的配置文件,建议先阅读 webpack 官网内容,具备一定基础后再进行修改。
hippy-vue 终端开发调试用编译配置
该配置展示了将 Hippy 运行于终端的最小化配置。
配置文件 | 说明 |
---|---|
hippy-webpack.dev.js | 调试用配置 |
hippy-vue 终端线上包配置
线上包和开发调试用包主要有两个区别:
- 开启了 production 模式,去掉调试信息,关闭了
watch
(watch 模式下会监听文件变动并重新打包)。 - 终端内很可能不止运行一个 Hippy 业务,所以将共享的部分单独拆出来做成了
vendor
包,这样可以有效减少业务包体积,这里使用了 DllPlugin 和 DllReferencePlugin 来实现。需要说明的是生成的vendor
包正常情况下是不需要特别更新的,但是如果更新了也要注意一下向上兼容性,不要因为分包导致业务崩溃。
配置文件 | 说明 |
---|---|
vendor.js | vendor 包中需要包含的共享部分 |
hippy-webpack.ios.js | iOS 业务包配置 |
hippy-webpack.ios-vendor.js | iOS Vendor 包配置 |
hippy-webpack.android.js | Android 业务包配置 |
hippy-webpack.android-vendor.js | Android Vendor 包配置 |
如果仔细观察 webpack 配置,可以看出 iOS 和 Android 配置差不多,但因为 iOS 上受苹果政策影响只能使用 JavaScriptCore(以下简称 JSC)作为运行环境,而 JSC 是跟随 iOS 操作系统的,无法进行独立升级,低版本 iOS 带的 JSC 甚至无法完整支持 ES6,所以需要输出一份 ES5 版本的 JS 代码。而 Android 下可以使用可以独立升级的 X5 中的 V8 作为运行环境,就可以直接使用 ES6 代码了。ES6 代码不但运行更快,体积还会更小一些。
特别说明:JS 方面可以使用的功能其实受到 iOS 覆盖最低版本的影响,绝大多数功能可以通过
@babel/preset-env
自动安装 polyfill,但是部分特性不行,例如要使用 Proxy,就无法覆盖 iOS 10 以下版本。
hippy-vue 入口文件
hippy-cli 初始化的项目自带了一个Web 端入口文件,可以保留着用来启动 Web 端网页,但是因为 hippy-vue 的启动参数不一样,需要专门的终端入口文件来加载一些终端上用到的模块。
import Vue from 'vue';
import VueRouter from 'vue-router';
import HippyVueNativeComponents from '@hippy/vue-native-components';
import App from './app.vue';
import routes from './routes';
import { setApp } from './util';
// 禁止框架调试信息输出,取消注释即可使用。
// Vue.config.silent = true;
Vue.config.productionTip = false;
// Hippy 终端组件扩展中间件,可以使用 modal、view-pager、tab-host、ul-refresh 等终端扩展组件了。
Vue.use(HippyVueNativeComponents);
Vue.use(VueRouter);
const router = new VueRouter(routes);
/**
* 声明一个 app,这是同步生成的
*/
const app = new Vue({
// 终端指定的 App 名称
appName: 'Demo',
// 根节点,必须是 Id,当根节点挂载时才会触发上屏
rootView: '#root',
// 渲染自己
render: h => h(App),
// iPhone 下的状态栏配置
iPhone: {
// 状态栏配置
statusBar: {
// 禁用状态栏自动填充
// disabled: true,
// 状态栏背景色,如果不配的话,会用 4282431619,也就是 #40b883 - Vue 的绿色
// 因为运行时只支持样式和属性的实际转换,所以需要用下面的转换器将颜色值提前转换,可以在 Node 中直接运行。
// hippy-vue-css-loader/src/compiler/style/color-parser.js
backgroundColor: 4283416717,
// 状态栏背景图,要注意这个会根据容器尺寸拉伸。
// backgroundImage: '//mat1.gtimg.com/www/qq2018/imgs/qq_logo_2018x2.png',
},
},
// 路由
router,
});
/**
* $start 是 Hippy 启动完以后触发的回调
* Vue 会在 Hippy 启动之前完成首屏 VDOM 的渲染,所以首屏性能非常高
* 在 $start 里可以通知终端说已经启动完成,可以开始给前端发消息了。
*/
app.$start((/* app */) => {
// 这里干一点 Hippy 启动后的需要干的事情,比如通知终端前端已经准备完毕,可以开始发消息了。
// setApp(app);
});
/**
* 保存 app 供后面通过 app 接受来自终端的事件。
*
* 之前是放到 $start 里的,但是有个问题时因为 $start 执行太慢,如果首页就 getApp() 的话可能会
* 导致获得了 undefined,然后监听失败。所以挪出来了。
*
* 但是终端事件依然要等到 $start 也就是 Hippy 启动之后再发,因为之前桥尚未建立,终端发消息前端也
* 接受不到。
*/
setApp(app);
hippy-vue npm script
最后在 package.json 中补上几个快速的 npm 脚本就可以了,这里以 hippy:
开头做好了范例,这里顺道做了一个到 hippy-debug-server 的快速启动命令。
"scripts": {
"hippy:debug": "hippy-debug",
"hippy:dev": "webpack --config ./scripts/hippy-webpack.dev.js",
"hippy:vendor": "webpack --config ./scripts/hippy-webpack.ios-vendor.js --config ./scripts/hippy-webpack.android-vendor.js",
"hippy:build": "webpack --config ./scripts/hippy-webpack.ios.js --config ./scripts/hippy-webpack.android.js"
},
路由
@hippy/vue-router
完整支持 vue-router 中的跳转功能,具体请参考 hippy-vue-router 文档。
hippy-vue 转 Web
hippy-vue 项目基于 vue-cli 生成的 Web 项目,之前的 Web 能力可以直接使用,对于使用 vue-cli 生产的项目,可以参考官方文档。