@cqingwang/react-native-split

React native bundle split tool.


Install
npm install @cqingwang/react-native-split@1.0.4

Documentation

React Native Bundle Splitter

Split config: splitconfig.

Why just an EXAMPLE (not a complete library)

RN Bundle split is not just "split", it should also take two point into consideration:

  • How to use them, means native code framework change, because RN native part not support loading script in demand.
  • Project structure, you should have a clean project dependency graph (recursive dependency is bad).

So, I don't want to make it to a library which be common to use.

In this example, it have clear project structure and some hack to RN framework (by reflection in Java). All split-bundle related code is in src directory, use them with pleasure:)

Project Structure

/root
 |- /src
   |- /components
     |- /packagea
       |- SampleA.js      => Entry1
       |- ApiOfSampleA.js => Refered in SampleA.js
     |- /packageb
       |- SampleB         => Entry2
       |- ApiOfSampleA.js => Refered in SampleA.js
   |- /modules 
     |- index.js      => Append to base
     |- ModuleA.js    => Refered in index.js
     |- ModuleB.js    => Refered in index.js
 |- base.js          => Entry of base
 |- resolveInject.js => Resolve splitted resource

Usage

npm install
node ../index.js --platform android --output build --config .splitconfig --dev false

See example run-example.sh.

Run Example

cd split-example
npm install
./run-example.sh

License

  Copyright 2015 Desmond Yao
  
  Licensed under the Apache License, Version 2.0 (the "License");
  you may not use this file except in compliance with the License.
  You may obtain a copy of the License at
  
   http://www.apache.org/licenses/LICENSE-2.0
  
  Unless required by applicable law or agreed to in writing, software
  distributed under the License is distributed on an "AS IS" BASIS,
  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  See the License for the specific language governing permissions and
  limitations under the License.