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目录拷贝过去调试运行起来即可。
目录
相关文章
|
存储 缓存 弹性计算
2024年阿里云最便宜云服务器出炉:61元、165元、99元、199元
2024年截止目前阿里云最便宜的云服务器已经出炉,轻量应用服务器2核2G3M带宽61元1年、2核4G4M带宽165元1年;云服务器经济型e实例2核2G3M带宽99元1年;云服务器通用算力型u1实例2核4G5M带宽199元1年。除此之外,还有幻兽帕鲁Palworld专用服务器4核16G10M带宽只要26.52元/1个月、79.56元/3个月、149.00元/6个月,8核32G10M带宽只要90.60元/1个月、271.80元/3个月。本文为大家分享2024年阿里云最便宜的各个云服务器。
10718 4
2024年阿里云最便宜云服务器出炉:61元、165元、99元、199元
|
机器学习/深度学习 搜索推荐 算法
计算机视觉教程6-1:图解双目视觉系统与立体校正原理
计算机视觉教程6-1:图解双目视觉系统与立体校正原理
1336 0
计算机视觉教程6-1:图解双目视觉系统与立体校正原理
|
6月前
|
安全 数据安全/隐私保护
图片压缩工具横评:zippic与tinypng全方位对比
图片压缩是提升工作效率的关键工具,广泛应用于自媒体、网站开发及设计协作。本文对比了两款主流工具 tinypng 与 zippic,在 UI 设计、压缩效果及安全性方面的表现,帮助用户根据实际需求做出选择。
1215 5
图片压缩工具横评:zippic与tinypng全方位对比
|
5月前
|
传感器 人工智能 供应链
智能体未来发展趋势:对标国家“十四五”AI规划的技术方向研判
《智能体技术发展白皮书(2024)》指出,自主、多模态、行业化智能体将成为未来三年核心方向。自主智能体实现动态决策,提升制造效率;多模态智能体优化人机交互,覆盖智能家居等场景;行业化智能体深度融合医疗、金融、教育等领域,推动数字化转型。预计2027年行业市场规模超800亿元,助力国家人工智能战略落地。(238字)
|
索引 Python
%g是什么
`%g` 是 Python 字符串格式化中的一种格式说明符,用于表示浮点数或整数,能自动选择最合适的表示法。当数值为整数时,它显示整数;当数值较大或含小数时,它选择科学记数法或小数点记数法,并去掉无用的零。例如:
2047 1
|
测试技术 API 数据安全/隐私保护
Python连接到Jira实例、登录、查询、修改和创建bug
通过使用Python和Jira的REST API,可以方便地连接到Jira实例并进行各种操作,包括查询、修改和创建Bug。`jira`库提供了简洁的接口,使得这些操作变得简单易行。无论是自动化测试还是开发工作流的集成,这些方法都可以极大地提高效率和准确性。希望通过本文的介绍,您能够更好地理解和应用这些技术。
1446 0
|
运维 监控 架构师
自动化运维的概念|学习笔记
快速学习自动化运维的概念
自动化运维的概念|学习笔记
|
Python
Python virtualenv 虚拟环境(详细使用,包含打包 exe/app )
Python virtualenv 虚拟环境(详细使用,包含打包 exe/app )
943 0
|
SQL 监控 测试技术
【操作系统】Linux性能优化诊断pidstat+mpstat详解
【操作系统】Linux性能优化诊断pidstat+mpstat详解
【操作系统】Linux性能优化诊断pidstat+mpstat详解

热门文章

最新文章