npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@areslabs/example-commonpack

v3.0.3

Published

### 注意事项

Downloads

77

Readme

自定义Common包

注意事项

以下注意事项请严格遵守!!!!!!!

  1. 基础类库有任何修改都需要重新集成Common包至原生APP中,业务包如果更改,可以不重新集成
  2. 同一个APP中的所有业务必须使用同一个common包,否则可能出现加载错误
  3. 业务拆分包在控制台发布新版本后,需重新打业务拆分包到原生APP中,否则新版本后仍然会触发下载
  4. 多个业务公用的组件库,需要下沉至基础组件库,缩小拆分包体积
  5. 不要手动修改 commonBundleConfig.android.jsoncommonBundleConfig.ios.json
  6. Common包集成到原生APP后需回归验证高UV是否可用。
  7. 建议单一团队维护Common包,并且使用Jenkins自动化工具实现自动打包并提交到原生工程。

1、 添加自定义Common依赖

执行以下命令安装自定义依赖

npm install
npm run cp
npm install --save XXX/XXXXX

jsbundles/JDReactCommon.js中直接require对应代码库即可。示例如下:

var XXXXLib = require('XXX/XXXXX');

如需使用自动提交脚本,需配置ares.properties文件来指定JSBundle以及资源文件的相对路径,如下所示:

# Android 代码库中 assets文件夹相对路径,用于Jenkins自动提交脚本,如为手动打包,无需配置。
CUSTOM_ANDROID_JDREACT_ASSETS=app/src/main/assets
# Android 代码库中 drawable文件夹相对路径,用于Jenkins自动提交脚本,如为手动打包,无需配置。
CUSTOM_ANDROID_JDREACT_DRAWABLE=app/src/main/res
# iOS 代码库中 react.bundle文件夹相对路径,用于Jenkins自动提交脚本,如为手动打包,无需配置。
CUSTOM_IOS_JDREACT_BUNDLE_PATH=JDReactLiteBaseUpgradeDemo/JDReactLiteBaseUpgradeDemo
# 公共图片库路径
COMMON_ASSETS=@ares/example-core-lib/src/assets

2、手动打包JDReactCommon

  • 手动打包需要清空本地所有依赖,防止出现缓存问题。

    rm -rf node_module
    rm -rf package-lock.json
    rm -rf yarn.lock
    npm cache clean --force
    npm install
    npm run cp
  • 执行以下命令即可打包,-p 为android或者ios

./scripts/make-common-jsbundles.sh -p android

完成后产物在outputBundle-android或outputBundle-ios中,需将对应产物提交到原生工程代码库中。

  • 发布自定义的Common。

    发布npm教程可以参考点击这里。执行以下命令进行发布

npm publish

3、在业务模块中配置Common包的配置文件

  • 在业务模块的代码中新增Common包配置文件(如果该文件已存在就不用配置了)

    在业务模块的代码中新增commonpack.config.js。内容示例如下:

module.exports = {
    //common包在npm上发布的包名
    commonpack: "JDReactCommon",
    //可选参数,业务包id起始值。默认为5000,最小5000,防止出现id冲突
    //如果commonBundleConfig.android.json 或者 commonBundleConfig.ios.json中最大的id超过5000,
    //需要适当设置businessStartID参数大小,默认是5000。并且所有业务需要统一,并且重新打所有业务拆分包。
    //businessStartID: 10000
}
  • 删除本地缓存,并重新安装(必需,需要用最新的Common包进行拆包)
rm -rf node_modules
rm -rf package-lock.json
npm install
npm install --save-dev JDReactCommon
  • 提交package.json

4、手动打业务拆分包到原生工程

手动打包需要清空本地所有依赖,防止出现缓存问题。

rm -rf node_module
rm -rf package-lock.json
rm -rf yarn.lock
npm cache clean --force
npm install

执行以下命令即可拆包,-p 为平台,可选参数为android、ios。-m 为模块名字

./scripts/make-business-jsbundles-standalone.sh -p ios -m JDReactAPIDemos

业务拆分包产物在outputBundle中,需将对应产物提交到原生工程代码库中。

5、Jenkins自动集成Common包到原生工程

本脚本主要功能如下:打Common包,并提交至对应平台的原生代码中,并发布npm,将该修改到本git中。 配置如下: 注:需提前clone原生工程到Jenkins机器,并给该git账户push权限。

export PATH=$PATH:/usr/local/bin
npm cache clean --force
npm install
npm run cp
#auto-build-commonpack-standalone.sh 参数说明
# 参数1:平台 ios或android
# 参数2:git仓库地址,事先clone的ios或android原生工程的仓库地址
# 参数3:原生工程代码分支
# 参数4: 打Common包的JS代码分支
./scripts/auto-build-commonpack-standalone.sh 'ios' 原生工程git仓库地址 ${Branch} ${jsBranch}

6、Jenkins自动集成业务拆分包到原生工程

本脚本主要功能如下:打业务拆分包,并提交至对应平台的原生代码中。 配置如下: 注:需提前clone原生工程到Jenkins机器,并给该git账户push权限。

export PATH=$PATH:/usr/local/bin
rm -rf outputBundle
rm -rf node_modules
rm -rf scripts
rm -rf yarn.lock
rm -rf package-lock.json
npm install
#auto-commit-jsbundles-standalone.sh 参数说明
# 参数1:平台 ios或android
# 参数2:git仓库地址,事先clone的ios或android原生工程的仓库地址
# 参数3:原生工程代码分支
# 参数4: 业务包moduleName
./scripts/auto-commit-jsbundles-standalone.sh 'ios' 原生工程git仓库地址 $Branch $moduleName