While resolving: @vue/composition-api@1.7.2
Found: vue@2.7.16
node_modules/vue
vue@"^2.7.16" from the root project
前端使用了yarn 来管理包
linux下安装yarn
方式一 官网脚本执行一键安装
curl -o- -L https://yarnpkg.com/install.sh | bash -s -- --nightly
方式二 通过npm安装
npm install -g yarn
Yarn 常用命令
查看版本: yarn --version
创建文件夹 yarn: md yarn
进入yarn文件夹: cd yarn
初始化项目:yarn init
同npm init,执行输入信息后,会生成package.json文件
yarn的配置项:
yarn config list #显示所有配置项
yarn config get <key> #显示某配置项
yarn config delete <key> #删除某配置项
yarn config set <key> <value> [-g|--global] #设置配置项
添加依赖包:
(会更新package.json和yarn.lock):
yarn add [package] // 在当前的项目中添加一个依赖包,会自动更新到package.json和yarn.lock文件中
yarn add [package]@[version] // 安装指定版本,这里指的是主要版本,如果需要精确到小版本,使用-E参数
yarn add [package]@[tag] // 安装某个tag(比如beta,next或者latest)
不指定依赖类型默认安装到dependencies里,你也可以指定依赖类型:
yarn add --dev/-D // 加到 devDependencies
yarn add --peer/-P // 加到 peerDependencies
yarn add --optional/-O // 加到 optionalDependencies
默认安装包的主要版本里的最新版本,下面两个命令可以指定版本:
yarn add --exact/-E // 安装包的精确版本。例如yarn add foo@1.2.3会接受1.9.1版,但是yarn add foo@1.2.3 --exact只会接受1.2.3版
yarn add --tilde/-T // 安装包的次要版本里的最新版。例如yarn add foo@1.2.3 --tilde会接受1.2.9,但不接受1.3.0
将依赖项添加到不同依赖项类别:
不指定依赖类型默认安装到dependencies里,你也可以指定依赖类型分别添加到 devDependencies、peerDependencies 和 optionalDependencies
yarn add [package] --dev 或 yarn add [package] -D // 加到 devDependencies
yarn add [package] --peer 或 yarn add [package] -P // 加到 peerDependencies
yarn add [package] --optional 或 yarn add [package] -O // 加到 optionalDependencies
升级依赖包:
yarn upgrade [package] // 升级到最新版本
yarn upgrade [package]@[version] // 升级到指定版本
yarn upgrade [package]@[tag] // 升级到指定tag
安装依赖包:
yarn install //安装package.json里所有包,并将包及它的所有依赖项保存进yarn.lock
yarn install --flat //安装一个包的单一版本
yarn install --force //强制重新下载所有包
yarn install --production //只安装dependencies里的包
yarn install --no-lockfile //不读取或生成yarn.lock
yarn install --pure-lockfile //不生成yarn.lock
发布依赖包:
yarn publish
移除依赖包:
yarn remove <packageName>:移除一个包,会自动更新package.json和`yarn.lock`
更新一个依赖:
yarn upgrade 用于更新包到基于规范范围的最新版本
运行脚本:
yarn run 用来执行在 package.json 中 scripts 属性下定义的脚本
显示某个包的信息
yarn info <packageName> 可以用来查看某个模块的最新版本信息
yarn cache 缓存
yarn cache list 列出已缓存的每个包
yarn cache dir 返回 全局缓存位置
yarn cache clean 清除缓存
yarn 和 npm 命令对比
在包管理工具的选择上,Yarn和npm各有其特点和优势。以下是两者的比较分析:
安装速度:Yarn使用了并行化的策略来处理依赖项的安装,这意味着它会同时处理多个任务,从而提高了性能。而npm在早期版本中是按队列顺序一个接一个地安装依赖项,这可能会导致安装过程比Yarn慢。
锁定文件:Yarn默认会生成一个yarn.lock文件,记录了所有依赖的确切版本号,确保团队成员之间安装的依赖一致性。而npm需要运行shrinkwrap命令来生成npm-shrinkwrap.json文件,才能达到类似的效果。
依赖管理:Yarn和npm都使用加密哈希算法来确保包的完整性,这是两者共有的特性。不过,Yarn在处理依赖关系时更加积极,它会尽可能地减少文件的大小和数量。
使用技巧:Yarn支持一些便利的命令,如使用yarn config set registry命令可以改变npm的镜像源,这对于国内用户来说是一个实用的功能。而npm也提供了丰富的命令集合,但在某些操作上可能需要更多的配置。
总的来说,Yarn在性能和依赖管理方面有一定的优势,尤其是在提高安装速度和简化依赖锁定方面。而npm作为Node.js官方支持的包管理工具,拥有庞大的生态系统和广泛的用户基础,也在不断改进和更新,以提供更好的用户体验。
参考链接:https://blog.csdn.net/qq_63055262/article/details/135776853
npm install 换成 yarn install 后打包就可以顺利进行了。