当前位置: 首页 > 面试题库 >

npx和npm之间的区别?

濮冠宇
2023-03-14
问题内容

我刚刚开始学习React,facebook通过提供以下现成的项目来帮助简化初始设置。链接到Github上的Facebook帐户 :

如果必须安装框架项目,则必须npx create-react-app my-app在命令行中键入。我想知道为什么Github中的facebook帐户npx create-react-app my-app没有npm create-react-app my-app


问题答案:

npx简介:npm包运行器

NPM- 管理 软件包, 执行 任何任务都不容易。NPX- 执行 Node包的工具。

NPX随附NPM版本5.2+

NPM本身并不能简单地运行任何软件包。事实上,它不会运行任何程序包。如果要使用NPM运行软件包,则必须在package.json文件中指定该软件包。

通过NPM软件包安装可执行文件时,NPM链接到它们:

  1. 本地 安装在./node_modules/.bin/目录中创建了“链接” 。
  2. 全局 安装具有从Linux或Windows 上的全局bin/目录(例如/usr/local/bin)创建的“链接” %AppData%/npm

NPM:

一个人可能会在某个项目的本地安装软件包:

npm install some-package

现在,假设您希望NodeJS从命令行执行该程序包:

$ some-package

以上将 失败 。只有 在全球安装 的软件包可以通过输入自己的名字被执行

要解决此问题并使其运行,必须输入本地路径:

$ ./node_modules/.bin/some-package

从技术上讲,您可以通过编辑packages.json文件并在以下scripts部分中添加该软件包来运行本地安装的软件包:

{
  "name": "whatever",
  "version": "1.0.0",
  "scripts": {
    "some-package": "some-package"
  }
}

然后使用npm run-script(或npm run)运行脚本

npm run some-package

npx将检查,或本地项目二进制文件中是否<command>存在$PATH,并执行它。因此,对于上面的示例,如果您希望执行本地安装的软件包some-package,则只需输入:

npx some-package

另一个 主要 优点npx是能够执行以前未安装的软件包:

$ npx create-react-app my-app

上面的示例将在命令运行的路径内生成一个react应用样板,并确保您始终使用最新版本的生成器或构建工具,而不必每次使用时都进行升级。



 类似资料:
  • 除了npm update modify package.json之外,这些命令之间的本质区别是什么?

  • 问题内容: 我想问一下您最喜欢JS的软件包管理器是什么?我看到了一些关于yarn和npm的文章。但是我不确定有什么对我更好。我刚刚开始学习JS。 现在,yarn和npm之间的差异对我来说就像可乐品牌之间的差异。 问题答案: 有时候我们只有一个,但是解决依赖性和缓存问题太多,以至于另一个工具诞生了()。通常,它使用本地缓存来解决依赖关系,例如,在运行几乎总是在同一环境中运行的CI作业时,这非常关键,

  • 问题内容: 我错放了太多次了,我想我一直忘记,因为我不知道两者之间的区别,只是一个给了我我期望的价值,而另一个却没有。 为什么是这样? 问题答案: 是的简写形式(尽管请注意,该表达式只会被计算一次。) 是的,即指定一元的到。 例子:

  • 问题内容: 因此,我有一段简单的代码可以打印出整数1-10: 然后,如果仅在第3行上更改一个运算符,它将打印出无限数量的1整数(我知道为什么会这样做)。为什么在运行第二个程序时没有出现语法错误?如果赋值运算符后面跟着一个加法运算符,它不会调用语法错误吗? 问题答案: 与相同, 只是意味着。

  • 问题内容: 有人可以解释一下 和 我不知道“确切”的含义 问题答案: 在这个例子中,什么都没有。当您具有多个具有相似名称的路径时,该参数将起作用: 例如,假设我们有一个显示用户列表的组件。我们还有一个用于创建用户的组件。的网址应嵌套在下。因此,我们的设置可能如下所示: 现在,这里的问题是,当我们转到路由器时,将通过所有定义的路由,并返回它找到的第一个匹配项。因此,在这种情况下,它将首先找到路线,然