当前位置: 首页 > article >正文

Vue3 + Vitest 浏览器测试 从零开发指南

一、我们要做什么写一个Vue3 计数器组件显示名字 点按钮数字1写Vitest 自动化测试让电脑自动验证功能是否正确全程不用弹浏览器在终端就能看到测试结果 ✅二、准备工作只需要 1 个软件安装Node.js一路下一步https://nodejs.org/安装完打开VS Code终端输入检查node-vnpm-v出现版本号 成功三、第一步创建项目1. 新建文件夹名字叫vue-vitest-demo2. VS Code 打开文件夹文件 → 打开文件夹 → 选择你创建的文件夹3. 打开终端顶部 → 查看 → 终端4. 初始化项目npminit-y执行完会生成package.json项目配置文件四、第二步安装所有依赖直接复制运行运行这条命令安装所有需要的工具npminstall-Dvitest vue/test-utils jsdom vitejs/plugin-vue typescript vue安装完成后你的package.json里会出现这些依赖。五、第三步创建项目文件结构你的项目必须长成下面这样不能错vue-vitest-demo/ ├─ src/ │ └─ HelloWorld.vue (组件) │ └─ HelloWorld.spec.ts (测试文件) ├─ vitest.config.ts (测试配置) ├─ tsconfig.json (TS配置) ├─ vue.shim.d.ts (TS识别Vue) └─ package.json六、第四步复制代码全部给你准备好了1. src/HelloWorld.vue组件script setup langts // 导入Vue响应式功能 import { ref } from vue // 定义组件接收的参数必须传name是字符串 defineProps{ name: string }() // 定义响应式数字count默认值1 const count ref(1) /script template div !-- 展示名字和计数器 -- h1Hello {{ name }} x{{ count }}!/h1 !-- 点击按钮count1 -- button clickcountIncrement/button /div /template2. src/HelloWorld.spec.ts测试文件import{expect,test}fromvitestimport{mount}fromvue/test-utilsimportHelloWorldfrom./HelloWorld.vuetest(renders name and the counter,async(){// 挂载组件传入 name 属性constwrappermount(HelloWorld,{props:{name:Vitest},})// 检查页面是否显示 Hello Vitestexpect(wrapper.text()).toContain(Hello Vitest)// 模拟点击按钮awaitwrapper.find(button).trigger(click)// 检查点击后数字变成 2expect(wrapper.text()).toContain(2)})3. vitest.config.ts测试配置import{defineConfig}fromvitest/configimportvuefromvitejs/plugin-vueexportdefaultdefineConfig({plugins:[vue()],test:{environment:jsdom,},})4. tsconfig.jsonTypeScript 配置{compilerOptions:{target:ESNext,lib:[esnext,dom],module:ESNext,moduleResolution:Bundler,strict:true,declaration:true,noEmit:true,esModuleInterop:true,skipLibCheck:true}}5. vue.shim.d.ts让 TS 认识 Vue 文件declaremodule*.vue{importtype{DefineComponent}fromvue;constcomponent:DefineComponent{},{},any;exportdefaultcomponent;}6. package.json添加测试命令找到scripts改成scripts:{test:vitest}七、第五步运行测试见证成功在终端输入npmruntest你会看到RERUN src/HelloWorld.spec.ts x1 ✓ src/HelloWorld.spec.ts (1 test) 26ms ✓ renders name and the counter 25ms Test Files 1 passed Tests 1 passed✅全部跑通八、每一步我们干了什么1. HelloWorld.vue写了一个页面组件接收名字name显示Hello xxx x1!点击按钮数字 12. HelloWorld.spec.ts写了一个自动测试脚本自动加载组件自动检查文字是否正确自动点击按钮自动检查数字是否变成 23. 配置文件让TypeScript Vitest Vue能一起工作。4. 运行测试电脑自动帮你测试功能不用你手动点页面九、常见问题2. TS 报红检查vue.shim.d.ts是否创建检查tsconfig.json是否正确3. 命令报错重新运行安装命令npminstallps:https://cn.vitest.dev/ https://github.com/vitest-tests https://changweihua.github.io/zh-CN/blog/2025-09/vue-vitest.html https://betterstack.com/community/guides/testing/vitest-explained/

相关文章:

Vue3 + Vitest 浏览器测试 从零开发指南

一、我们要做什么? 写一个 Vue3 计数器组件(显示名字 点按钮数字1)写 Vitest 自动化测试(让电脑自动验证功能是否正确)全程不用弹浏览器,在终端就能看到测试结果 ✅二、准备工作(只需要 1 个软…...

人工智能学习之归一化和标准化的区别

归一化与标准化(机器学习核心预处理笔记) 核心前提:机器学习中,特征的量纲(单位)可能差异极大(如:身高cm、体重kg、收入万元),会导致模型(如KNN、…...

电动汽车高压系统狭窄空间高精度电流电压测量方案解析

1. 项目概述:当高压测量遇上“螺蛳壳里做道场”在电动汽车的研发测试领域,尤其是实车道路测试阶段,有一个场景让很多工程师头疼不已:如何在发动机舱、底盘或电池包附近那些错综复杂、空间逼仄的线束通道里,精准地测量高…...

工业物联网主板布局设计:从i.MX28x核心到无线模块的硬件规划

1. 项目概述:从一块板卡看工业物联网的“骨架”拿到一块名为“IoT-A28LI”的主板,标题里还带着“i.MX28x系列”和“无线工控板”这样的关键词,这立刻让我这个在工业控制和嵌入式领域摸爬滚打多年的老工程师来了兴致。这不仅仅是一块电路板&am…...

重磅喜报!中国星坤入围东莞上规资助计划,政企携手共筑智造标杆

近日,东莞市工业和信息化局正式公布 2026 年支持工业企业上规发展做大做强项目拟资助计划,中国星坤(XKB Connection)凭借在电子连接器领域的技术实力与稳健发展,成功入选,成为东莞智造升级的标杆企业之一东…...

20260520 OVN网络整体实验

OVN网络整体实验 [rootcontroller ~ 16:26:09]# source keystonerc_admin [rootcontroller ~(keystone_admin)]# openstack network agent list --------------------------------------------------------------------------------------------------------------------------…...

Best Practice for AI Agents Project _ Chapter 1

很高兴he大家分享,《AI智能体项目最佳实践》内容,系统覆盖从单智能体工程基础,到私有知识注入、能力扩展、安全设计,再到多智能体协同的完整企业AI落地路径。本次分享第一章:从模型调用到可靠的单智能体(Fr…...

跨境电商作图不纠结!风格全覆盖, AI 工具帮你省超多心

做跨境电商这么多年,最头疼的从来不是选品和运营,而是作图!不同平台风格要求不一样、不同国家审美差异大、小白没设计基础、外包贵还改到崩溃… 相信不少跨境卖家都跟我一样,在作图这件事上踩过无数坑。今天就以老卖家的身份&…...

工程机械重型车辆检测数据集 YOLO格式

数据集格式:YOLO格式(包含jpg图片以及对应的yolo格式的txt标注文件) 图片预览: 标注例子: 图片数量(jpg文件个数):6338 标注数量(txt文件个数):6338 标注类别数:7 标注类别名称:["Bull_dozer"…...

实时仿真软件SimuRTS

1)简介 SimuRTS是一款实时仿真软件,应用于硬件在环(HIL)嵌入式系统半实物仿真测试。基于SimuRTS的用户界面快速配置I/O通道、数据记录和激励生成。通过丰富的图形元素配置图形控制界面并根据需要显示相应结果,全面测试…...

别再死记硬背了!用这5个HBase Shell实战场景,轻松搞定日常数据操作

HBase Shell实战手册:5个真实场景解锁高效数据操作 在数据爆炸式增长的时代,HBase作为分布式NoSQL数据库的佼佼者,凭借其高吞吐、低延迟的特性,成为处理海量结构化数据的首选方案。然而,许多开发者虽然掌握了基础命令&…...

极竞魔方XR大空间亮相孩子王南京城市亲子节

在这个周末的南京,空气中除了初夏的微热,更多的是属于家庭的欢笑声。由母婴童行业领军品牌“孩子王”倾力打造的南京城市亲子节现场人头攒动,成为了全城瞩目的焦点。在琳琅满目的展位与高频互动的游乐项目中,孩子和家长正排队解锁…...

别再傻傻分不清L2和L3了!一张图看懂自动驾驶分级(附SAE/国标对照表)

自动驾驶分级全解析:从L0到L5的技术演进与商业应用 当特斯拉车主开启Autopilot功能在高速公路上行驶,或是蔚来汽车宣传其NOP领航辅助时,这些究竟属于什么级别的自动驾驶?为什么有些厂商称自己的系统为"L2.999"&#xff…...

从推荐逻辑到库存架构:木鸟民宿、携程民宿、爱彼迎场景化服务技术对比

摘要从技术和产品设计的角度看,木鸟民宿、携程民宿、爱彼迎三家平台在场景化服务上究竟走了怎样不同的技术路径?各自用了哪些手段把“住宿”这件事匹配到用户真实的生活场景里?三家平台在技术落地上各有侧重。木鸟民宿主打“标签化即时确认”…...

GJB/Z 299D-2024 可靠性预计工具 —— 国产自主可控的电子设备可靠性评估利

📌 工具简介GJBZ299D可靠性预计工具 是一款基于国军标 GJB/Z 299D-2024《电子设备可靠性预计手册》 开发的专业化桌面应用程序。采用 应力分析法,对电子设备的各类元器件进行工作失效率(λp)计算,自动汇总 MTBF/MTF 等…...

[特殊字符] 零基础搭建「知识科普讲师」数字人|魔珐星云实战指南

在短视频、知识付费、自媒体赛道,知识科普、职场干货、生活常识、读书分享内容需求越来越大。真人出镜成本高、拍摄慢、文案难量产,而AI 数字人讲师可以做到:文案好写、生成快、24 小时可播、风格稳定、形象专业。 本文基于魔珐星云具身智能…...

一文搞懂 MySQL:一条 SQL 语句的完整执行之旅

你是否每天都在写 SQL,却从未想过它在 MySQL 内部是如何一步步执行的?今天我们就通过这张经典的 MySQL 执行流程图,带你拆解一条 SQL 从客户端发送到结果返回的完整过程,搞懂这个过程,你就能轻松理解 SQL 优化、事务原…...

Semi Design v2.98.0 发布:多项组件功能更新与问题修复,助力搭建美观 React 应用

【Feature】新增douyinfe/semi-vite-plugin包,提供 Vite 构建场景下的主题定制等能力,与douyinfe/semi-webpack-plugin特性对齐;Calendar 组件新增onMoreClickprop,支持自定义月视图下"还有几项"的点击事件;…...

青铜器RDM:CBB 模块全周期管控,赋能研发高效复用

阶段 1、痛点与定位在研发项目中,CBB 通用基础模块是提升研发效率、降低研发成本、保障产品可靠性的核心关键。如何高效管理、复用、评价 CBB?青铜器 RDM 系统给出一站式解决方案。阶段 2、资源库搭建与全周期管控系统内置标准化 CBB 资源库,…...

从YOLOv5实战反推:手把手在WSL2里搭建PyTorch 1.12 + CUDA 11.3 环境(附国内镜像加速)

逆向工程视角:在WSL2中构建YOLOv5专属PyTorch 1.12CUDA 11.3开发环境 当目标检测项目的截止日期迫在眉睫,却卡在环境配置环节,这种体验对开发者而言无异于噩梦。本文将以结果导向的逆向思维,从YOLOv5的最终运行需求出发&#xff0…...

别再死记硬背了!用Python+SymPy玩转含参积分,从卷积到信号处理一次搞懂

用PythonSymPy玩转含参积分:从数学原理到信号处理实战 数学中的含参积分常常让学习者感到抽象难懂,尤其是当涉及到极限交换、求导与积分顺序交换等概念时。但如果我们换一种方式——用代码和可视化来探索这些数学概念,一切就会变得清晰起来。…...

多目摄像头时间同步实战:用FSYNC信号搞定树莓派+双OV5640的同步曝光

多目摄像头时间同步实战:用FSYNC信号搞定树莓派双OV5640的同步曝光 在机器人视觉和立体成像项目中,双摄像头同步采集图像是许多应用的基础需求。无论是构建双目视觉系统、全景拼接还是运动分析,毫秒级的时间差都可能导致算法失效。我曾在一个…...

电池级氢氧化锂粉碎设备选型指南:氮气保护气流粉碎机详解

氢氧化锂(LiOH)具有易吸潮、强碱性、有一定粘附性的特点,且在电池级应用中对金属杂质污染零容忍。因此,行业主流不推荐传统的机械碾压式磨机(如雷蒙磨,容易引入铁屑且密封难),而是首…...

Amphenol DRPC11A009040线束解析

随着服务器、高速通信设备以及工业控制系统对高速传输性能要求不断提升,越来越多工程师开始关注高可靠性线束组件的选型问题。其中,来自 Amphenol ICC 的 DRPC11A009040 线束组件,近年来在高速连接领域中被广泛关注。 作为国际连接器品牌的重…...

高通平台Sensor驱动移植避坑指南:以QCM6490平台BMI160为例,从编译到上电调试全流程

高通平台Sensor驱动移植实战:QCM6490平台BMI160全流程避坑指南 1. 环境准备与基础架构解析 在QCM6490平台上进行BMI160传感器驱动移植前,必须充分理解高通SEE架构的设计理念。与传统的SSC架构相比,SEE架构通过模块化封装大幅降低了移植复杂度…...

公域卖课佣金高、粉丝留不住?这套私域打法,完课率提升了3倍

公域卖课的两大痛点痛点一:佣金太高,利润被吃掉一大块。相信在公域卖过课的朋友都有体会。平台抽成、分销佣金、投流成本……七七八八算下来,到手的钱可能连一半都不到。你辛辛苦苦打磨的课程,大头却被别人拿走了。这感觉&#xf…...

手把手教你用W25Q32 SPI Flash:从波形图看懂擦除、写入和读取(附完整代码)

手把手教你用W25Q32 SPI Flash:从波形图看懂擦除、写入和读取(附完整代码) 在嵌入式开发中,SPI Flash存储器因其高性价比、大容量和简单接口而广受欢迎。W25Q32作为一款32Mb的SPI Flash芯片,被广泛应用于物联网设备、消…...

为 OpenClaw 配置 Taotoken 作为自定义 OpenAI 兼容供应商

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 为 OpenClaw 配置 Taotoken 作为自定义 OpenAI 兼容供应商 OpenClaw 是一个流行的开源 Agent 框架,它允许开发者通过配…...

从审稿人到作者:我审了10篇论文后,总结出的5个投稿避坑指南和3个加分项

从审稿人到作者:10篇论文审阅经验提炼的5大避坑策略与3个关键加分项 第一次收到审稿邀请时,我正对着自己第三篇被拒的论文修改意见发呆。这种身份错位带来的震撼,让我开始系统记录审稿笔记——如今这些笔记已形成超过2万字的"审稿人思维…...

本地视频怎么去水印?2026最全去水印方法与软件推荐

如果你经常从各个视频平台保存视频素材,水印问题往往让人头疼。本地视频上的水印可能是平台logo、主播昵称、或者其他标识。今天就为你盘点本地视频去水印的多种方法,以及2026年最实用的去水印软件推荐,助你快速解决视频水印困扰。 本地视频去…...