QAP内建包迁移教程

简介: 前言 最新千牛客户端内置了最新版本的NukeUI和QAP-SDK, 开发者可以不再打包相关的代码,经测试内建包可以大幅降低QAP package包的大小,体积最大可减少75%~80%的大小。推荐旧的QAP包升级。

前言

最新千牛客户端内置了最新版本的NukeUI和QAP-SDK, 开发者可以不再打包相关的代码,经测试内建包可以大幅降低QAP package包的大小,体积最大可减少75%~80%的大小。推荐旧的QAP包升级。

升级过程

安装最新的qap-cli

执行以下shell脚本

## cnpm install qap-cli@beta -g   更正: 新的qap-cli已经支持,请使用如下命令安装

cnpm install qap-cli -g  

当前版本还为beta,所以需要增加@beta安装

安装rax-webpack-plugin

在旧项目下目录下执行以下脚本

cnpm install rax-webpack-plugin --save

替换修改 RxPlugin的引用

  • 在webpack.config.js文件里找到以下代码

var RxPlugin = require('weex-rx-webpack-plugin');
修改为以下代码
var RxPlugin = require('rax-webpack-plugin');

  • 找到在new RxPlugin()的地方

修改为如下:

new RxPlugin({
    target: 'bundle'
})

修改.bablerc文件

找到根目录下.bablerc文件,找到如下代码并删除

["transform-imports", {
        "nuke": {
            "transform": "nuke/lib/${member}",
            "preventFullImport": true
        },
}]

注意还需要删除这段代码前面的一个逗号 ,

增加外部引用的配置

修改webpack.config.js

1.在config对象里增加以下代码

"externals": [{
    "weex-rx": "commonjs rax",
    "rax": "commonjs rax",
    "nuke": "commonjs nuke",
    "QAP-SDK": "commonjs QAP-SDK",
    "genv": "commonjs genv",
}],

增加框架识别代码

在webpack.config.js文件里找到如下代码

new webpack.optimize.UglifyJsPlugin({
            minimize: true,
            compress: { warnings: false, drop_console: true },
            output: { comments: false }
        })

在其后边增加

,
new webpack.BannerPlugin('// {"framework": "Rax"}', {raw: true})

注意new前边的逗号

修改页面的渲染方式

  • 引入render

增加render在weex-rx
import {createElement, Component, render} from 'weex-rx';

  • 修改mount为render

找到所有的页面,修改下边

mount(<XXX/>, 'body');

render(<XXXX/>);
  • 删掉页面所有如下代码
import {mount} from 'nuke-mounter';

后续更新

  • 删除package.json里 dependencies 对象的的nuke 和weex-rx,和QAP-SDK的相关行。
  • 需要修改所有 nuke-XXXX 开头的模块,改为全部import XXX form nuke,
  • 需要修改所有 import XXX from nuke-XXXimport XXX from nuke

建议全局搜索 nuke-,并做修改和替换
修改后如果发现不能运行,请联系群里的童鞋帮忙处理。

升级总结

经过以上简单几步,即可完成内建包的配置。
以上升级最主要包含了几个部分

  • weex-rx 模块名称已经不再使用, 建议以后都使用rax, 可以全局搜索 weex-rx并替换为rax
  • nuke-mounter 模块不再使用,以后都只使用
import {render} from 'rax';
  • 如果工程的配置修改不大,最简单的方法是用qap init newProject,生成一个新的工程,然后把src目录拷贝过去调试运行起来即可。
目录
相关文章
|
6月前
|
数据采集 Linux 测试技术
如何选择适合的LabVIEW版本进行开发
如何选择适合的LabVIEW版本进行开发
103 1
|
编译器 C语言
tslib.1.19 移植安装的问题和步骤
tslib.1.19 移植安装的问题和步骤
220 1
tslib.1.19 移植安装的问题和步骤
SAP ABAP——包的创建(一)【包概要简述】
本文主要对SAP ABAP中的包的概要进行一个讲解,主要包括了包概述,传输层和软件组件
922 1
SAP ABAP——包的创建(一)【包概要简述】
|
分布式计算 Ubuntu Hadoop
五十八、Ubuntu搭建hadoopHA高可用(从零开始)(一)
五十八、Ubuntu搭建hadoopHA高可用(从零开始)(一)
五十八、Ubuntu搭建hadoopHA高可用(从零开始)(一)
|
缓存
「OushuDB」版本升级 二进制替换升级步骤
请注意需要留下足够的升级与测试时间,避免升级出现问题需要回退到老版本。另外,请在升级前做好数据的备份工作,防止出现意外。
128 0
学习笔记(01):【吴刚】PS软件基础实用技巧标准视频教程-04-文件的打开及注意事项...
学习笔记(01):【吴刚】PS软件基础实用技巧标准视频教程-04-文件的打开及注意事项...
126 0
|
Serverless Java Python
开发函数计算的正确姿势 —— 依赖安装方法一览
1. 前言 首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute): 函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传。
4016 0
|
Serverless Linux Docker
手把手教您将 Ghostscript 移植到函数计算平台
前言 首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute):函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传。函数计算准备计算资源,并以弹性伸缩的方式运行用户代码,而用户只需根据实际代码运行所消耗的资源进行付费。
9531 0
|
消息中间件 Kafka 数据安全/隐私保护