全面解析:npm 命令、package.json 结构与 Vite 详解

全面解析:npm 命令、package.json 结构与 Vite 详解

一、npm run devnpm run build 命令解析

1. npm run dev
  • 作用:启动开发服务器,用于本地开发
  • 原理
    • 启动 Vite 开发服务器
    • 提供实时热更新(HMR)功能
    • 不生成最终打包文件,直接在内存中编译
  • 特点
    • 极速启动(毫秒级)
    • 按需编译(只编译当前访问的模块)
    • 完整源码映射(方便调试)
2. npm run build
  • 作用:构建生产环境优化的应用包
  • 原理
    • 调用 Vite 的 Rollup 构建引擎
    • 执行 TypeScript 编译、Vue 单文件组件编译
    • 应用 Tree Shaking(移除未使用代码)
  • 输出
    • 生成 dist/ 目录
    • 压缩所有资源文件(JS、CSS、图片)
    • 添加内容哈希到文件名(缓存优化)

二、package.json 文件深度解析

标准 Vue + Vite 项目的 package.json 示例:
{"name": "vue-project","version": "1.0.0","private": true,"scripts": {"dev": "vite","build": "vite build","preview": "vite preview","lint": "eslint . --ext .vue,.js,.ts --fix"},"dependencies": {"vue": "^3.3.0","pinia": "^2.1.0","axios": "^1.4.0"},"devDependencies": {"@vitejs/plugin-vue": "^4.0.0","@vue/eslint-config-typescript": "^11.0.0","eslint": "^8.22.0","typescript": "^5.0.0","vite": "^4.0.0","vite-plugin-eslint": "^1.8.1"},"browserslist": ["> 1%","last 2 versions","not dead"]
}
各部分详细说明:
字段作用示例值重要说明
name项目名称"vue-project"必须小写,不含空格
version项目版本"1.0.0"遵循语义化版本规范
private防止误发布true重要安全设置
scripts自定义命令见下表项目操作入口
dependencies生产依赖vue, pinia会被打包进最终代码
devDependencies开发依赖vite, typescript只在开发时使用
browserslist浏览器兼容">1%"控制编译输出目标
scripts 详解:
命令作用等效命令
npm run dev启动开发服务器vite
npm run build构建生产包vite build
npm run preview本地预览生产包vite preview
npm run lint代码规范检查eslint . --fix

三、Vite 深度解析

1. Vite 是什么?

Vite(法语意为"快速")是由 Vue.js 作者尤雨溪开发的下一代前端构建工具,核心特点:

  • 基于原生 ES 模块:利用浏览器原生支持 ES 模块的特性
  • 极速冷启动:启动时间与项目大小无关
  • 按需编译:只编译当前屏幕需要的模块
  • 高效热更新:HMR 速度极快,不受项目规模影响
2. Vite 核心架构:
浏览器
Vite 开发服务器
原生 ES 模块导入
按需编译
热模块替换 HMR
生产构建
Rollup 打包
Tree Shaking
代码分割
资源优化
3. Vite 核心功能对比:
功能ViteWebpack优势
启动时间<1s10-60s+快 10-100 倍
HMR 更新<50ms500ms-5s即时反馈
构建方式按需编译全量打包高效开发
配置复杂度简单复杂零配置起步
构建工具RollupWebpack输出更精简
4. Vite 核心插件系统:
  • @vitejs/plugin-vue:Vue 单文件组件支持
  • @vitejs/plugin-vue-jsx:Vue JSX 支持
  • vite-plugin-eslint:集成 ESLint
  • vite-plugin-svg-icons:SVG 图标处理
  • vite-plugin-mock:API 模拟数据

四、完整开发工作流

1. 开发阶段工作流:
开发者 Vite 服务器 浏览器 npm run dev 发送 HTML 骨架 请求 /src/main.ts 返回原生 ES 模块 请求 Vue 组件 实时编译并返回 修改组件代码 HMR 热更新(<50ms) 开发者 Vite 服务器 浏览器
2. 构建阶段工作流:
npm run build
读取 vite.config.ts
启动 Rollup 构建
编译 TypeScript
处理 Vue SFC
优化 CSS
处理静态资源
代码分割
Tree Shaking
生成 dist 目录
优化后的生产包

五、Vite 高级特性

1. 依赖预构建:
// vite.config.ts
export default defineConfig({optimizeDeps: {include: ['vue', 'pinia', 'lodash-es'],exclude: ['vue-demi']}
})
2. 环境变量处理:
# .env.development
VITE_API_BASE=/api# .env.production
VITE_API_BASE=https://api.example.com
// 代码中使用
const apiBase = import.meta.env.VITE_API_BASE
3. 多目标构建:
// vite.config.ts
export default defineConfig({build: {lib: {entry: 'src/main.ts',name: 'MyLib',fileName: 'my-lib'},rollupOptions: {// 导出为库时配置external: ['vue'],output: {globals: {vue: 'Vue'}}}}
})

六、最佳实践建议

  1. 项目结构优化

    src/
    ├── assets/        # 静态资源
    ├── components/    # 通用组件
    ├── composables/   # 组合式函数
    ├── layouts/       # 布局组件
    ├── router/        # 路由配置
    ├── stores/        # 状态管理
    ├── views/         # 页面组件
    ├── utils/         # 工具函数
    ├── App.vue        # 根组件
    └── main.ts        # 入口文件
    
  2. 性能优化技巧

    • 使用动态导入实现路由懒加载
    const UserProfile = () => import('./views/UserProfile.vue')
    
    • 启用 Gzip/Brotli 压缩
    npm install vite-plugin-compression -D
    
  3. 调试技巧

    • 使用 vite-plugin-inspect 查看中间状态
    • 添加 --debug 参数获取详细日志
    npm run dev -- --debug
    

七、与传统工具对比总结

特性ViteWebpackParcel
启动速度⚡️ 极快🐢 慢🚀 快
HMR 性能⚡️ 极快🐢 慢🚀 快
配置复杂度😊 简单😫 复杂😊 零配置
插件生态🌱 成长中🌳 成熟🌿 中等
框架支持Vue/React/Svelte 优先通用通用
生产构建Rollup(优化好)Webpack(功能强)自定义

Vite 代表了前端构建工具的新方向,特别适合现代框架如 Vue、React 的开发,通过利用浏览器原生 ESM 能力,彻底解决了传统工具在大型项目中启动慢、HMR 延迟高的痛点。

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

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

相关文章

【Oracle】TCL语言

个人主页&#xff1a;Guiat 归属专栏&#xff1a;Oracle 文章目录 1. TCL概述1.1 什么是TCL&#xff1f;1.2 TCL的核心功能 2. 事务基础概念2.1 事务的ACID特性2.2 事务的生命周期 3. COMMIT语句详解3.1 COMMIT基础语法3.2 自动提交与手动提交3.3 提交性能优化 4. ROLLBACK语句…

OpenCV CUDA模块直方图计算------用于在 GPU 上执行对比度受限的自适应直方图均衡类cv::cuda::CLAHE

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 cv::cuda::CLAHE 是 OpenCV 的 CUDA 模块中提供的一个类&#xff0c;用于在 GPU 上执行对比度受限的自适应直方图均衡&#xff08;Contrast Limi…

OpenGAN:基于开放数据生成的开放集识别

简介 简介&#xff1a;这次学习的OpenGAN主要学习一个思路&#xff0c;跳出传统GAN对于判断真假的识别到判断是已知种类还是未知种类。重点内容不在于代码而是思路&#xff0c;会简要给出一个设计的代码。 论文题目&#xff1a;OpenGAN: Open-Set Recognition via Open Data …

随机游动算法解决kSAT问题

input&#xff1a;n个变量的k-CNF公式 ouput&#xff1a;该公式的一组满足赋值或宣布没有满足赋值 算法步骤&#xff1a; 随机均匀地初始化赋值 a ∈ { 0 , 1 } n a\in\{0,1\}^n a∈{0,1}n.重复t次&#xff08;后面会估计这个t&#xff09;&#xff1a; a. 如果在当前赋值下…

企业上线ESOP电子作业指导书系统实现车间无纸化的投入收益数据综合分析

企业上线ESOP电子作业指导书系统实现车间无纸化的投入收益数据综合分析 一、成本节约&#xff1a;无纸化直接降低运营成本 纸张与耗材费用锐减 o 杭州科创致远案例&#xff1a;某汽配企业引入无纸化系统后&#xff0c;年节省纸张耗材费用超50万元。通过电子化替代传统纸质文档…

高并发抽奖系统优化方案

引子 最近接触了一个抽奖的项目&#xff0c;由于用户量比较大&#xff0c;而且第三方提供的认证接口并发量有限&#xff0c;为了保证服务的高可用性&#xff0c;所以对高并限制发有一定的要求。经过一系列研究和讨论&#xff0c;做出了以下一些优化方案。 需求分析 根据用户量…

STM32八股【10】-----stm32启动流程

启动流程 1.上电复位 2.系统初始化 3.跳转到 main 函数 启动入口&#xff1a; cpu被清空&#xff0c;程序从0x00000000开始运行0x00000000存放的是reset_handler的入口地址0x00000000的实际位置会变&#xff0c;根据不同的启动模式决定启动模式分为&#xff1a; flash启动&a…

LLMTIME: 不用微调!如何用大模型玩转时间序列预测?

今天是端午节&#xff0c;端午安康&#xff01;值此传统佳节之际&#xff0c;我想和大家分享一篇关于基于大语言模型的时序预测算法——LLMTIME。随着人工智能技术的飞速发展&#xff0c;利用大型预训练语言模型&#xff08;LLM&#xff09;进行时间序列预测成为一个新兴且极具…

在VirtualBox中打造高效开发环境:CentOS虚拟机安装与优化指南

&#x1f525;「炎码工坊」技术弹药已装填&#xff01; 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、为何选择VirtualBox CentOS组合&#xff1f; 对于程序员而言&#xff0c;构建隔离的开发测试环境是刚需。VirtualBox凭借其跨平台支持&#xff08;W…

LeeCode 98. 验证二叉搜索树

给你一个二叉树的根节点 root &#xff0c;判断其是否是一个有效的二叉搜索树。 有效 二叉搜索树定义如下&#xff1a; 节点的左子树只包含 小于 当前节点的数。节点的右子树只包含 大于 当前节点的数。所有左子树和右子树自身必须也是二叉搜索树。 提示&#xff1a; 树中节…

Python简易音乐播放器开发教程

&#x1f4da; 前言 编程基础第一期《12-30》–音乐播放器是日常生活中常用的应用程序&#xff0c;使用Python和pygame库可以轻松实现一个简易的音乐播放器。本教程将详细讲解如何开发一个具有基本功能的音乐播放器&#xff0c;并解析其中涉及的Python编程知识点。 &#x1f6e…

ssh连接断开,保持任务后台执行——tmux

目录 **核心用途****基础使用方法**1. **安装 tmux**2. **启动新会话**3. **常用快捷键&#xff08;需先按 Ctrlb 前缀&#xff09;**4. **会话管理命令**5. **窗格操作进阶** **典型工作流****注意事项****配置文件&#xff08;~/.tmux.conf&#xff09;** tmux&#xff08; …

3D Gaussian splatting 04: 代码阅读-提取相机位姿和稀疏点云

目录 3D Gaussian splatting 01: 环境搭建3D Gaussian splatting 02: 快速评估3D Gaussian splatting 03: 用户数据训练和结果查看3D Gaussian splatting 04: 代码阅读-提取相机位姿和稀疏点云3D Gaussian splatting 05: 代码阅读-训练整体流程3D Gaussian splatting 06: 代码…

每日c/c++题 备战蓝桥杯(P1204 [USACO1.2] 挤牛奶 Milking Cows)

P1204 [USACO1.2] 挤牛奶 Milking Cows - 详解与代码实现 一、题目背景 三个农民每天清晨[……]&#xff08;简要介绍题目背景&#xff0c;与官网描述类似&#xff09; 二、问题分析 输入要求 &#xff1a;读取 N 个农民的挤奶时间区间&#xff0c;计算两个值&#xff1a;最…

保持本地 Git 项目副本与远程仓库完全同步

核心目标&#xff1a; 保持本地 Git 项目副本与 GitHub 远程仓库完全同步。 关键方法&#xff1a; 定期执行 git pull 命令。 操作步骤&#xff1a; 进入项目目录&#xff1a; 在终端/命令行中&#xff0c;使用 cd 命令切换到你的项目文件夹。执行拉取命令&#xff1a; 运行…

Flutter 4.x 版本 webview_flutter 嵌套H5

踩坑早期版本 使用 WebView 代码如下 import package:flutter/material.dart; import package:webview_flutter/webview_flutter.dart;class HomePage extends StatelessWidget {const HomePage({super.key});overrideWidget build(BuildContext context) {return Scaffold(ap…

rtpinsertsound:语音注入攻击!全参数详细教程!Kali Linux教程!

简介 2006年8月至9月期间&#xff0c;我们创建了一个用于将音频插入指定音频&#xff08;即RTP&#xff09;流的工具。该工具名为rtpinsertsound。 该工具已在Linux Red Hat Fedora Core 4平台&#xff08;奔腾IV&#xff0c;2.5 GHz&#xff09;上进行了测试&#xff0c;但预…

跑步前热身动作

跑前热身的核心目标是升高体温、激活肌肉、预防损伤 &#xff0c;同时通过动态动作提升运动表现。热身&#xff08;步骤关节→肌肉→心肺&#xff09;和针对性动作&#xff08;如抱膝抬腿&#xff09;能有效降低受伤风险&#xff0c;建议每次跑步前严格执行。 推荐跑前热身动作…

GIT命令行的一些常规操作

放弃修改 git checkout . 修改commit信息 git commit --amend 撤销上次本地commit 1、通过git log查看上次提交的哈希值 2、git reset --soft 哈希值 分支 1.创建本地分支 git branch 分支名 2.切换本地分支 git checkout mybranch&#xff1b; 3.创建一个新分支并…

RAGFlow从理论到实战的检索增强生成指南

目录 前言 一、RAGFlow是什么&#xff1f;为何需要它&#xff1f; 二、RAGFlow技术架构拆解 三、实战指南&#xff1a;从0到1搭建RAGFlow系统 步骤1&#xff1a;环境准备 步骤2&#xff1a;数据接入 步骤3&#xff1a;检索与生成 四、优化技巧&#xff1a;让RAGFlow更精…