一个 create-react-app v5 的问题

sxkk20082年前知识分享138

前言

前两天我准备用 create-react-app 创建一个新项目,然后我在命令行下执行

npx create-react-app my-app

命令行下就会提示

Need to install the following packages:
  create-react-app
Ok to proceed? (y) y

You are running `create-react-app` 4.0.3, which is behind the latest release (5.0.0).

We no longer support global installation of Create React App.

Please remove any global installs with one of the following commands:
- npm uninstall -g create-react-app
- yarn global remove create-react-app

The latest instructions for creating a new app can be found here:
https://create-react-app.dev/docs/getting-started/

提示意思是:create-react-app 从第五版本开始不再需要全局安装,让我先卸载 create-react-app

然后我就输入 npm uninstall -g create-react-app 进行全局卸载,然后再执行 npx create-react-app my-app 创建,结果还是上面的提示。

npx 介绍

npm 从 5.2 版开始,增加了 npx 命令。它有很多用处,主要使用有以下场景。

调用项目中的安装模块

原先要执行

node-modules/.bin/jest

代替

npx jest

避免全局安装模块

npx create-react-app my-app

上面代码运行时,npx 将create-react-app下载到一个临时目录,使用以后再删除。

然后我去 google 搜索答案,找到了这个issue,上面回答了一些解决办法。

使用不同版本的 node

利用 npx 可以下载模块这个特点,可以指定某个版本的 Node 运行脚本。它的窍门就是使用 npm 的  node 模块

npx node@0.12.8 -v

上面命令会使用 0.12.8 版本的 Node 执行脚本。原理是从 npm 下载这个版本的 node,使用后再删掉。

某些场景下,这个方法用来切换 Node 版本,要比 nvm 那样的版本管理器方便一些。

执行 GitHub 源码

npx 还可以执行 GitHub 上面的模块源码。

执行 Gist 代码

npx https://gist.github.com/zkat/4bc19503fe9e9309e2bfaa2c58074d32

执行仓库代码

npx github:piuccio/cowsay hello

注意,远程代码必须是一个模块,即必须包含package.json和入口脚本

原因

产生这个问题的原因是 npx 是有缓存的,但全局卸载后,npx 的缓存还在。

解决办法

方案一 使用固定版本号

npx create-react-app@5 <PROJECT_NAME>

方案二 使用 npm init代替

npm init react-app my-app

方案三
先清除 npx 缓存然后在初始化

npx clear-npx-cache
npx create-react-app my-app

以上就是本文全部内容,希望这篇文章对大家有所帮助,也可以参考我往期的文章或者在评论区交流你的想法和心得,欢迎一起探索前端。

本文首发掘金平台,来源小马博客

相关文章

人工智能:探索未来智能化世界的契机

人工智能:探索未来智能化世界的契机

  近年来,人工智能的发展取得了巨大进展,成为推动社会进步的重要力量之一。从机器学习到深度学习,从语音识别到图像识别,人工智能正在逐渐融入生产、服务、交通、医疗等各个领域。在...

一天内筛选超1亿种化合物,AI语言模型“提速”药物发现

一天内筛选超1亿种化合物,AI语言模型“提速”药物发现

  美国麻省理工学院和塔夫茨大学研讨人员设计出一种依据大型言语模型(如ChatGPT)的人工智能算法,这种称为ConPLex的新模型可将方针蛋白与潜在的药物分子相匹配,而无需...

新的文档采用了全新的架构 next.js + Tailwind CSS ,改版后的文档界面有种焕然一新的感觉,支持暗黑模式,我们可以在线学习,并且写代码,采用了这种所见即所得的形式,大大降低了学习者的成本,我也被这种形式所深深吸引,那么这种所见即所得的形式是如何实现的呢?

基本介绍

新文档地址在 https://github.com/reactjs/reactjs.org/ 中的 beta 目录下,外层代码是目前的文档代码,那么我们可以直接 git clone 并且拷贝 beta 目录下的内容

这里面有 yarn.lock 文件,跟绝大多数 next 项目一样 yarn install 之后,运行 yarn dev 就可以运行开发环境

s16501401132022

启动速度非常快,仅仅 3.3s, 打开 http://localhost:3000,此时 next.js 会再次编译,大概 200ms,这种优势得益于 next.js 按需编译的优势,也就是是说当前启动的时候,并不会全站打包,而是当进入某个页面的时候编译当前页面,所以速度相当快。

约定式路由

s16384301132022 next 是约定式路由,在 pages 文件夹下的目录默认生成路由,即 '/src/pages/learn/add-react-to-a-website.md' 生成路由 /learn/add-react-to-a-website

此时发现里面的文档都是.md后缀的 Markdown 文件,那么 markdown 也可以写交互功能了吗? image.png

React 新的文档用到了哪些技术?

前言https://beta.reactjs.org React 的新的文档已经 完成了 70 % 并且呼吁社区进行翻译工作。 新的文档采用了全新的架构 next.js + Tailwind CSS...

马拉松报名提醒河北全马 田协认证?2024石家庄马拉松开启报名

闲话马拉松2024厦马惊现不雅照 摄影平台是否应该推出隐私模式?小马过河2024-01-087900 两点思考:一是跑友在马拉松赛道上的行为举止应该谨慎;二是摄影平台应该考虑跑友的信息或隐私安全,是否...

百度天工:人工智能的引领者与探索者

百度天工:人工智能的引领者与探索者

  近年来,人工智能技术以其强大的学习和推理能力赢得了广泛关注和应用。在这个领域的先驱者和探索者之一,就是中国科技巨头百度旗下的“百度天工”(Baidu Research...

全AI绘画:当艺术与科技相遇

全AI绘画:当艺术与科技相遇

  人工智能(AI)技术的发展已经彻底改变了各行各业的运作方式,在文化领域也不例外。现如今,AI绘画技术已经得到了广泛的关注和使用。 从大数据到深度学习,再到生成对抗网络...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。