运行vue2源码,最适合的nodejs版本和yarn版本

Node.js 版本

  • Node.js 14.x:这是一个长期支持(LTS)版本,在许多 Vue 2 项目开发和部署中被广泛采用。它提供了良好的性能和稳定性,并且与大多数 Vue 2 生态系统的工具和依赖兼容。
perl 复制代码
# 使用 Node.js 14.x
nvm use 14

Yarn 版本

对于 Yarn,建议使用 Yarn 1.x(也称为 Yarn Classic)。Yarn 1.x 是一个成熟且广泛使用的包管理工具,在 Vue 2 项目开发中具有良好的兼容性和稳定性。

sql 复制代码
npm install -g yarn@1
yarn -v
yarn add typescript@latest --dev

忽略警告

如果更新依赖或者指定版本都不可行,且这个警告不会影响项目的正常运行,你可以选择忽略这个警告。不过,这只是一个临时的解决方案,建议你在合适的时机对依赖进行升级。

在运行项目时,可以使用 --no-fund--no-audit 参数来减少不必要的警告输出:

使用 npm

css 复制代码
npm install --no-fund --no-audit

使用 yarn

css 复制代码
yarn install --no-fund --no-audit

ts报错

swift 复制代码
Type '{ component: () => Promise<Component<DefaultData<never>, DefaultMethods<never>, DefaultComputed, Record<string, any>>>; }' is not assignable to type 'void | Promise<EsModule<Component<DefaultData<never>, DefaultMethods<never>, DefaultComputed, Record<string, any>>>> | { component: Promise<EsModule<Component<DefaultData<never>, DefaultMethods<...>, DefaultComputed, Record<...>>>>; loading?: VueConstructor<...> | ... 3 more ... | undefined;

解决方案:

typescript

typescript 复制代码
import { Component } from 'vue';

// 假设 EsModule 是一个包装组件的类型
type EsModule<T> = { default: T };

type AsyncComponent = () => {
  component: Promise<EsModule<Component>>;
  loading?: any;
  error?: any;
  delay?: number;
  timeout?: number;
};

const b: AsyncComponent = () => ({
  // 直接返回 Promise<EsModule<Component>>
  component: new Promise<EsModule<Component>>((res, rej) => {
    res({ default: { template: "" } });
  }),
  // 你可以根据需要添加 loading、error、delay 和 timeout 属性
});

解释

  • 定义了 EsModule 类型,用于包装组件。
  • 确保 component 属性直接返回 Promise<EsModule<Component>>,而不是返回 Promise 的函数。
  • res({ default: { template: "" } }) 保证了返回的 Promise 解析为一个具有 default 属性的对象,该属性包含组件定义。
相关推荐
夏之小星星14 分钟前
el-tree结合checkbox实现数据回显
前端·javascript·vue.js
琉璃℡初雪1 小时前
vue2/3 中使用 @vue-office/docx 在网页中预览(docx、excel、pdf)文件
vue.js·pdf·excel
拖孩3 小时前
【Nova UI】十五、打造组件库之滚动条组件(上):滚动条组件的起步与进阶
前端·javascript·css·vue.js·ui组件库
苹果电脑的鑫鑫3 小时前
element中表格文字剧中可以使用的属性
javascript·vue.js·elementui
Hejjon4 小时前
Vue2 elementUI 二次封装命令式表单弹框组件
前端·vue.js
Wannaer4 小时前
从 Vue3 回望 Vue2:响应式的内核革命
前端·javascript·vue.js
赵大仁5 小时前
React vs Vue:点击外部事件处理的对比与实现
javascript·vue.js·react.js
coderYYY7 小时前
多个el-form-item两列布局排齐且el-select/el-input组件宽度撑满
前端·javascript·vue.js·elementui·前端框架
Watermelo6178 小时前
前端如何应对精确数字运算?用BigNumber.js解决JavaScript原生Number类型在处理大数或高精度计算时的局限性
开发语言·前端·javascript·vue.js·前端框架·vue·es6
HebyH_8 小时前
2025前端面试遇到的问题(vue+uniapp+js+css)
前端·javascript·vue.js·面试·uni-app