从零开始快速构建Vue3项目

一、技术选型

组件大类

具体插件

vue3插件

相关插件开发文档

基础架构搭建

初始项目搭建、打包构件工具:vite开始 | Vite
路由管理及菜单权限封装vue-router介绍 | Vue Router
状态管理Pinia介绍 | Pinia 中文文档
API请求及异常封装axios
UI框架
 
element-uihttps://element-plus.org/zh-CN/guide/nav.html
ant design vueAnt Design Vue — An enterprise-class UI components based on Ant Design and Vue.js
样式解析、自定义、主题less/sass/scss/stylus
国际化及自动化工具i18n
开发风格统一ESLint + Prettier+提交规范

二、快速构建项目

一)从头开始创建项目

方式1、从头构建 Vue 3 项目

1、使用 Vite

        Vite是目前最推荐的方式来创建 Vue 3 项目,因为它速度快,配置简洁,并且是 Vue 3 的官方推荐工具。

npm create vite@latest my-vue3-project --template vue //创建项目
npm install //安装依赖
npm run dev //运行项目

打开浏览器并访问 `http://localhost:5173`,你将看到一个基本的 Vue 3 应用程序运行。

注意:

        1、若需要使用不同版本node(兼容新旧项目环境),则需要使用nvm来进行node多版本管理,下载nvm-windows并安装。

nvm install 18    # 安装 Node.js 18.x
nvm ls  # 查看当前已安装的 Node.js 版本
nvm use 18    # 切换到 Node.js 18.x

        2、若出现某个依赖安装报错,可以npm install --ignore-scripts,最后再来单独安装报错的依赖。

2、使用 Vue CLI

如果您正在从零开始构建新的 Vue 项目,尤其是基于 Vue 3,Vite 是推荐的选择。

  • Vite 非常适合新项目、需要快速开发和高效构建的大型项目、现代化开发环境。
  • Vue CLI 更适合已经使用 webpack 的旧项目、需要复杂配置或对现有生态非常依赖的项目。

方式2、使用已有的模板/项目

Vitesse:一个开箱即用的 Vue 3 + Vite 模板,集成了 TypeScript、Pinia、Vue Router、国际化支持等。

PanJiaChen/vue-element-admin:基于 Vue 和 Element Plus 构建的后台管理系统,功能丰富且高度可定制。

vueComponent/ant-design-vue-pro:基于 Ant Design Vue 构建的后台管理系统,提供了类似于 Ant Design Pro 的体验。

anncwb/vue-vben-admin:模块化、易扩展,提供丰富的组件和功能,如权限控制、国际化、多标签页、图表等。

二)构建过程问题

1、依赖安装

这个错误表示在使用 pnpm 安装依赖时,尝试从 GitHub 上拉取某个依赖包时遇到了权限问题。具体来说,你的本地机器未正确配置用于 SSH 访问 GitHub 的公钥。以下是如何解决的步骤:

解决方法:

  1. 检查 SSH 密钥是否存在

    • 确保你的本地机器上已配置了 SSH 密钥:

      ls ~/.ssh/id_rsa.pub

    • 如果文件不存在,使用以下命令生成 SSH 密钥:

      ssh-keygen -t rsa -b 4096 -C "your_email@example.com"

  2. 将 SSH 公钥添加到 GitHub

                cat ~/.ssh/id_rsa.pub

  • 登录 GitHub 并导航到 Settings > SSH and GPG keys
  • 点击 New SSH key,然后粘贴公钥并保存。
  1. 测试 SSH 连接到 GitHub

    • 验证 SSH 是否正常工作:
      ssh -T git@github.com 
    • 如果配置正确,你会看到一条欢迎消息。
  2. 修改 GitHub URL 使用 HTTPS

如果不想使用 SSH,可以将 git URL 改为 HTTPS,以避免使用 SSH 密钥。

git config --global url."https://github.com/".insteadOf "git@github.com:"

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/60494.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

74HC245

74HC245:典型的CMOS型缓冲门电路 在这里用于增加电压

BFS 算法专题(三):BFS 解决边权为 1 的最短路问题

目录 1. 迷宫中离入口最近的出口 1.1 算法原理 1.2 算法代码 2. 最小基因变化 ★★★ 2.1 算法原理 2.2 算法代码 3. 单词接龙 3.1 算法原理 3.2 算法代码 4. 为高尔夫比赛砍树 (hard) 4.1 算法原理 4.2 算法代码 1. 迷宫中离入口最近的出口 . - 力扣(…

hive的tblproperties支持修改的属性

文章目录 一、介绍二、查看TBLPROPERTIES属性三、修改TBLPROPERTIES属性 一、介绍 TBLPROPERTIES用途:向表中添加自定义或预定义的元数据属性,并设置它们的赋值。在hive建表时,可设置TBLPROPERTIES参数修改表的元数据,也能通过AL…

「数据要素」行业简报|2024.11.上刊

纵观数据要素行业动态,洞察行业风向,把握行业脉搏! 一、政策发布 1、《山东省公共数据资源登记管理工作规范(试行)》公开征求意见 11月7日,为认真贯彻落实《中共中央办公厅 国务院办公厅关于加快公共数据资源开发利用的意见》《…

Paddle分布式训练报NCCL错

应该是没有装NCCL,但是通过NVIDIA官网方式用apt安装报错,说nccl签名有问题 打开官网查找对应版本的nccl:https://developer.nvidia.com/nccl/nccl-legacy-downloads 这里不下载local Ubuntu选项,下载O/S agnostic local install…

有什么好用的 WebSocket 调试工具吗?

在开发和测试 WebSocket 应用程序时,确保客户端能够正确地与服务器建立连接、发送和接收消息是非常重要的。 市面上有许多通用的 API 测试工具,它们大多专注于 HTTP 请求,而对于 WebSocket 的支持则显得较为有限。这种局限性使得开发者在寻找…

python私有化get和set的使用

私有化的好处 封装性:私有化有助于实现良好的封装,这是面向对象编程的核心原则之一。通过隐藏类的内部实现细节,可以减少外部对类的内部状态的直接访问和修改,从而保护对象的状态。 接口稳定性:私有化可以使得类的接口…

MQTT协议解析 : 物联网领域的最佳选择

1. MQTT协议概述 1.1 MQTT协议是什么 MQTT : Message Queuing Telemetry Transport 模式 : 发布 / 订阅主题优点 : 代码量小、低带宽、实时可靠应用 : 物联网、小型设备、移动应用MQTT 常用端口 : 1883 MQTT是一个网络协议,和HTTP类似,因为轻量简单&…

后端Node学习项目-用户管理-增删改查

model层实现 文件创建 在models文件夹下创建user.js 代码实现 const { DataTypes } require(sequelize) const { db } require(./index)const User db.define(user, {id: {type: DataTypes.INTEGER,primaryKey: true, // 主键autoIncrement: true, // 内容自增allowNull…

B+树的介绍

B树的概念 规则: B跟B树不同B树的非叶子节点不保存关键字记录的指针,只进行数据索引,这样使得B树每个非叶子节点所能保存的关键字大大增加 B树叶子节点保存了父节点的所有关键字记录的指针,所有数据地址必须要到叶子节点才能获取到。所以每次…

【Rust调用Windows API】获取正在运行的全部进程信息

前言 WIndows API官方文档 提供了C的调用示例,最近想尝试用Rust去实现,本系列博客记录一下实现过程。 依赖 Rust调用Windows API需要引入依赖winapi,在Cargo.toml中添加依赖 winapi "0.3.9"调用不同的API集就需要使用相应的功…

鸿蒙HarmonyOS 网络请求获取数据Http

注意的是;要为接口返回值指定类型 ,以及定义接口数据类型 index.ets import { http } from kit.NetworkKit;interface createAtType {date: number,}interface dataListType {createAt: createAtType;imgUrl: }Component export default struct TabBar {State dat…

2024136读书笔记|《飞鸟集》——使生如夏花之绚烂,死如秋叶之静美

2024136读书笔记|《飞鸟集》——使生如夏花之绚烂,死如秋叶之静美 《飞鸟集》[印]泰戈尔,一本有意思的诗集,中英文对照着读更有意思。“你是谁,读者,百年后读着我的诗?”让我觉得有些久别重逢,忽…

ROS Action

在 ROS 中,Action 是一种支持长时间异步任务的通信机制。与 Service 不同,Action 允许客户端发起一个请求,并在任务执行的过程中不断接收反馈,直到任务完成。这种机制非常适用于可能需要较长时间来完成的任务,比如机器…

C++设计模式和编程框架两种设计元素的比较与相互关系

C设计模式和编程框架都是软件设计中的重要元素,它们各自具有独特的特点和应用场景。以下是对它们的比较,并通过举例说明它们的关系。 C设计模式 定义 设计模式是在软件设计中反复出现的特定问题的解决方案。它们是经过验证的、可复用的设计方案&#…

约束(MYSQL)

not null(非空) unique(唯一) default(默认约束,规定值) 主键约束primary key(非空且唯一) auto_increment(自增类型) 复合主键 check&#xff08…

MySQL 权限困境:从权限丢失到权限重生的完整解决方案20241108

🛠️ MySQL 权限困境:从权限丢失到权限重生的完整解决方案 引言 在使用 MySQL 的过程中,我们常常会遇到权限设置不当或丢失的问题,特别是在初次安装或配置更改后。这种权限困境的修复不仅复杂,而且往往是环环相扣&…

笔记 | image may have poor performance,or fail,if run via emulation

在Docker Desktop中现象如图: 当你运行 AMD64 平台代码时(Intel 和 AMD 芯),你的 Mac 必须模拟其CPU架构(因为你自身是ARM)。这通常会非常吃性能。 Docker Desktop 警告你在模拟 Intel/AMD x64 CPU 时性能可…

【C++】C++11特性(上)

✨✨欢迎大家来到Celia的博客✨✨ 🎉🎉创作不易,请点赞关注,多多支持哦🎉🎉 所属专栏:C 个人主页:Celias blog~ 目录 一、列表初始化 二、std::initializer_list 三、右值引用和移…

【WebRTC】视频发送链路中类的简单分析(下)

目录 1.任务队列节流发送器(TaskQueuePacedSender)1.1 节流控制器添加RTP数据包(PacingController::EnqueuePacket())1.2 监测是否要处理Packet(PacingController::MaybeProcessPackets()) 2.数据包路由&am…