React-native:看起来你全局安装了 react-native

Posted

技术标签:

【中文标题】React-native:看起来你全局安装了 react-native【英文标题】:React-native: Looks like you installed react-native globally 【发布时间】:2016-10-23 07:26:17 【问题描述】:

在全局安装时,react-native 似乎存在错误。我需要它正确执行而不会看到此错误:

$ react-native run-ios
Looks like you installed react-native globally, maybe you meant react-native-cli?
To fix the issue, run:
npm uninstall -g react-native
npm install -g react-native-cli

其他论坛上发布的解决方案对我不起作用,我不明白为什么这不起作用。

package.json:


  "name": "react-native-svgkit",
  "version": "0.2.2",
  "main": "Svg.js",
  "description": "A <Svg /> element for react-native that renders Svg images using SVGKit",
  "author": "Brent Vatne <brentvatne@gmail.com> (https://github.com/brentvatne)",
  "peerDependencies": 
    "react": "15.1.0",
    "react-native": ">=0.4.4"
  ,
  "devDependencies": 
    "react-native": ">=0.4.4",
    "react-native-cli": "^0.1.10"
  ,
  "dependencies": 
    "d3": "^3.5.5",
    "jsdom-jscore": "^0.1.0",
    "react-native-svg": "^2.2.0"
  ,
  "repository": 
    "type": "git",
    "url": "git@github.com:brentvatne/react-native-svgkit.git"
  ,
  "scripts": 
    "start": "node /usr/local/lib/node_modules/react-native/local-cli/cli.js start"
  

【问题讨论】:

你是通过 npm 运行这个命令吗? 是的,它位于标准全球位置/usr/local/bin/react-native 你能分享你的 package.json 文件吗? react-native-svgkit 是一个旧项目,尚未开发,最新版本的 react-native 不支持。您是对 svg 库感兴趣还是想要升级和维护该库? 我感兴趣的不是使用库本身,而是一个将 SVG 带入最新 react-native 的库。 【参考方案1】:

出于某种原因,我 package.json 文件中删除了所有依赖项并手动安装它们

yarn add react-native redux

其余的对我有用, 我发现问题出在已安装软件包的版本上。

【讨论】:

redux 在这里做什么?【参考方案2】:

在 package.json 中使用它

"scripts": 
   "android": "node node_modules/react-native/local-cli/cli.js run-android"

而不是

"scripts": 
    "android": "react-native run-android"
 

【讨论】:

这成功了!但是你能告诉我什么是绝对路径吗?【参考方案3】:

在我的情况下,这个问题是因为 npm 是使用自制软件安装的。可以在this gist 上找到有关此问题的描述以及如何解决它。总之,所需的修复是卸载所有 npm 全局安装的包,卸载节点,然后重新安装节点,然后重新安装 npm 而不使用 brew。

npm list -g --depth=0 # to list all your globally installed packages
rm -rf /usr/local/lib/node_modules
brew uninstall node
brew install node --without-npm
echo prefix=~/.npm-packages >> ~/.npmrc
curl -L https://www.npmjs.com/install.sh | sh

然后,您必须重新安装所有使用 npm install -g &lt;package_name&gt; 全局安装的 npm 包。

不幸的是,当我重新启动我的机器时,同样的问题再次发生。我目前的工作是遵循here 的建议,即

npm install --save-dev react-native-cli

欢迎对正在发生的事情进行任何解释。

【讨论】:

npm install --save-dev react-native-cli 为我修复了它。

以上是关于React-native:看起来你全局安装了 react-native的主要内容,如果未能解决你的问题,请参考以下文章

你如何检测是不是在 react-native 中点击了屏幕的右半部分?

如何使用 npx 创建新的反应原生应用程序?

react-native 配置在安卓模拟器上运行

使用ClojureScript,Re-natal和React-Native禁用RTL?

记学习react-native

记学习react-native