【发布时间】:2019-05-02 13:27:32
【问题描述】:
react-native https://github.com/facebook/metro/issues/1 中仍未正式提供符号链接支持。
实际上可以将 package.json 中的符号链接与 npm(不是 yarn)一起使用
{
"name": "PROJECT",
"version": "0.1.0",
"private": true,
"scripts": {
"start": "node node_modules/react-native/local-cli/cli.js start",
"test": "jest"
},
"dependencies": {
"my_module1": "file:../shared/my_module1/",
"my_module2": "file:../shared/my_module2/",
"react": "16.8.3",
"react-native": "0.59.5",
},
"devDependencies": {
"babel-jest": "24.7.1",
"jest": "24.7.1",
"metro-react-native-babel-preset": "0.53.1",
"react-test-renderer": "16.8.3"
},
"jest": {
"preset": "react-native"
}
}
虽然我们会得到my_module1在急速模块地图中不存在
为了解决这个问题,我们可以在 metro.config.js(以前的 rn-cli.config.js)之前做
const path = require("path")
const extraNodeModules = {
/* to give access to react-native-firebase for a shared module for example */
"react-native-firebase": path.resolve(__dirname, "node_modules/react-native-firebase"),
}
const watchFolders = [
path.resolve(__dirname, "node_modules/my_module1"),
path.resolve(__dirname, "node_modules/my_module2"),
]
module.exports = {
resolver: {
extraNodeModules
},
watchFolders,
transformer: {
getTransformOptions: async () => ({
transform: {
experimentalImportSupport: false,
inlineRequires: false
}
})
}
}
不幸的是,它不再适用于 react-native 0.59 应用程序正在重新加载,但源代码的更改不会反映在应用程序中。任何人都有实现这一目标的线索?
【问题讨论】:
标签: react-native npm symlink