ExpoKit是"纯JS"Expo应用程序和"香草"React Native应用程序的混合体.它的核心仍然是一个React原生项目,但在构建系统、开发人员经验和可用功能方面有一些不同之处.
特征
到目前为止,Expo SDK中的大多数API都无法在本地项目中使用,但它们可以在ExpoKit中使用.我们认为这在future 可能会改变,但这将是一个很大的工作.
Expo的推送通知服务目前不适用于ExpoKit,也不适用于本地用户.
构建系统
vanilla RN应用程序和ExpoKit应用程序都使用Xcode和Android Studio来构建本机代码.iOS ExpoKit应用程序使用CoCoaPod安装依赖项,这会给管理本机构建增加一点复杂性.Android ExpoKit应用程序具有额外的Gradle配置,可以将多个版本的React Native构建到同一个二进制文件中(这用于支持对多个SDK版本的JS进行空中更新),这有时会增加添加其他React Native库的复杂性.
ExpoKit和React本机项目的JavaScript由Metro构建,不过在ExpoKit中,您需要使用Expo的XDE或exp工具运行Metro,以便它们能够处理项目的额外配置.这意味着您可以运行exp start
而不是react-native run-android
这样的命令.
由于ExpoKit的当前设计(尽管将来可能会发生变化),一些开源React本机库可能与ExpoKit存在兼容性问题.例如,如果本机库希望能够请求引用以在Android上React-native的OkHttp实例,则在ExpoKit内运行时可能会出现类型不匹配,因为Expo使用的命名空间允许编译多个版本的React-native.也就是说,这些问题往往非常罕见,我们正在研究几种不同的方法,使ExpoKit与生态系统中的库越来越兼容.
这种多版本支持还意味着ExpoKit二进制文件往往比相应的本地二进制文件大,尽管这在future 可能会改变.
你的子问题
- 一些开发人员更喜欢自己管理JS包和assets资源 的分发方式,或者他们可能需要一个目前与ExpoKit不兼容的库.二进制大小是您可能更喜欢香草RN的另一个原因.
- 目前不可能在React原生项目中使用大多数Expo API.Expo SDK中提供的一些API是从开源项目(如react native maps)Bundle 而来的,可以与vanilla RN项目一起使用.
- 我不知道如何解析这个问题——Expo API目前只是react 本机API,它们知道如何相互对话,并对它们运行的环境做出某些假设.
comments 1中的问题:您可以随心所欲地修改ExpoKit构建,但这可能会使升级到更新的SDK版本变得稍微困难,具体取决于您对它的编辑程度.