开发Vue.js组件的二三事

Vue.js作为一款渐进式JavaScript框架,其组件化开发模式是其核心优势之一。在多年的Vue开发实践中,我积累了一些组件开发的经验和思考,在此与大家分享。

组件设计原则

单一职责原则

每个组件应该只关注一个特定的功能或UI部分。如果一个组件变得过于复杂,考虑将其拆分为更小的子组件。

// 不好的做法 - 一个组件处理太多事情
Vue.component('user-dashboard', {// 包含了用户信息、订单列表、消息通知等
})// 好的做法 - 拆分为专注的子组件
Vue.component('user-profile', { /* ... */ })
Vue.component('order-list', { /* ... */ })
Vue.component('notification-bell', { /* ... */ })

可复用性

设计组件时要考虑其复用场景。通过props提供定制化选项,而不是硬编码特定行为。

props: {// 提供默认值但允许覆盖size: {type: String,default: 'medium',validator: value => ['small', 'medium', 'large'].includes(value)}
}

松耦合

组件应尽量减少对外部状态的依赖,通过事件通信而非直接修改父组件状态。

// 子组件
methods: {handleClick() {this.$emit('item-selected', this.item)}
}// 父组件
<template><child-component @item-selected="handleSelection" />
</template>

组件通信模式

Props向下传递

// 父组件
<child-component :title="pageTitle" :items="dataList" />// 子组件
props: {title: String,items: Array
}

事件向上传递

// 子组件
this.$emit('update', newValue)// 父组件
<child-component @update="handleUpdate" />

使用Provide/Inject

适合深层嵌套组件通信

// 祖先组件
provide() {return {theme: this.theme}
}// 后代组件
inject: ['theme']

使用Vuex/Pinia
对于全局状态管理

// store
state: {user: null
}// 组件
computed: {user() {return this.$store.state.user}
}

高级组件模式

动态组件

<component :is="currentComponent"></component>

异步组件

components: {'async-component': () => import('./AsyncComponent.vue')
}

渲染函数与JSX

render(h) {return h('div', {class: ['container', {'is-active': this.active}]}, this.$slots.default)
}

作用域插槽

<!-- 组件 -->
<template><div><slot :user="user" :profile="profile"></slot></div>
</template><!-- 使用 -->
<user-data v-slot="{ user, profile }">{{ user.name }} - {{ profile.age }}
</user-data>

组件测试

单元测试

import { shallowMount } from '@vue/test-utils'
import MyComponent from '@/components/MyComponent.vue'describe('MyComponent', () => {it('renders props.message when passed', () => {const msg = 'new message'const wrapper = shallowMount(MyComponent, {propsData: { message: msg }})expect(wrapper.text()).toMatch(msg)})
})

E2E测试

describe('MyComponent', () => {it('navigates to about page', () => {cy.visit('/')cy.get('[data-test="about-link"]').click()cy.url().should('include', '/about')})
})

性能优化

懒加载组件

components: {'heavy-component': () => import('./HeavyComponent.vue')
}

使用v-once

<div v-once>{{ staticContent }}</div>

合理使用v-if和v-show

<!-- 频繁切换用v-show -->
<div v-show="isVisible">...</div><!-- 不常显示用v-if -->
<modal v-if="showModal" />

常见陷阱与解决方案

​​避免直接修改props​

// 不好的做法
this.internalValue = this.value
this.internalValue = newValue // 直接修改// 好的做法
watch: {value(newVal) {this.internalValue = newVal}
},
methods: {updateValue(newVal) {this.$emit('input', newVal)}
}

合理使用key​​

列表渲染时,key应该使用唯一标识而非索引

<!-- 不好的做法 -->
<div v-for="(item, index) in items" :key="index"><!-- 好的做法 -->
<div v-for="item in items" :key="item.id">

避免过度嵌套插槽​​

过度嵌套插槽会导致代码难以维护,考虑使用渲染函数替代复杂插槽结构。

结语

Vue组件开发是一门艺术,需要在封装性、复用性和灵活性之间找到平衡。随着Vue 3的Composition API等新特性的引入,组件开发模式也在不断演进。希望这些经验能帮助你在Vue组件开发中少走弯路,构建出更优雅、更可维护的前端应用。

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

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

相关文章

实现多路视频截图预览之后上传到后台系统

********************父组件********************** <div class"camera-box" v-loading"i.loading"> <div class"camera-box-inner" v-for"(x, y) in i.children" :key"y children x.featureCode" v-show"…

分布式锁-Redisson实现

目录 本地锁的局限性 Redisson解决分布式锁问题 在分布式环境下&#xff0c;分布式锁可以保证在多个节点上的并发操作时数据的一致性和互斥性。分布式锁有多种实现方案&#xff0c;最常用的两种方案是&#xff1a;zookeeper和redis&#xff0c;本文介绍redis实现分布式锁方案…

【办公类-48-04】202506每月电子屏台账汇总成docx-5(问卷星下载5月范围内容,自动获取excel文件名,并转移处理)

背景需求&#xff1a; 1-4月电子屏表格&#xff0c;都是用这个代码将EXCEL数据整理成分类成3个WORD表格。 【办公类-48-04】20250118每月电子屏台账汇总成docx-4&#xff08;提取EXCLE里面1月份的内容&#xff0c;自制月份文件夹&#xff09;-CSDN博客文章浏览阅读1.2k次&…

【websocket】安装与使用

websocket安装与使用 1. 介绍2. 安装3. websocketpp常用接口4. Websocketpp使用4.1 服务端4.2 客户端 1. 介绍 WebSocket 是从 HTML5 开始支持的一种网页端和服务端保持长连接的 消息推送机制。 传统的 web 程序都是属于 “一问一答” 的形式&#xff0c;即客户端给服务器发送…

微算法科技(NASDAQ:MLGO)基于信任的集成共识和灰狼优化(GWO)算法,搭建高信任水平的区块链网络

随着数字化转型的加速&#xff0c;区块链技术作为去中心化、透明且不可篡改的数据存储与交换平台&#xff0c;正逐步渗透到金融、供应链管理、物联网等多个领域&#xff0c;探索基于信任的集成共识机制&#xff0c;并结合先进的优化算法来提升区块链网络的信任水平&#xff0c;…

【项目实战】通过多模态+LangGraph实现PPT生成助手

PPT自动生成系统 基于LangGraph的PPT自动生成系统&#xff0c;可以将Markdown文档自动转换为PPT演示文稿。 功能特点 Markdown解析&#xff1a;自动解析Markdown文档结构PPT模板分析&#xff1a;分析PPT模板的布局和风格智能布局决策&#xff1a;匹配内容与合适的PPT布局自动…

贝叶斯优化+LSTM+时序预测=Nature子刊!

贝叶斯优化与LSTM的融合在时间序列预测领域取得了显著成效&#xff0c;特别是在处理那些涉及众多超参数调整的复杂问题时。 1.这种结合不仅极大提高了预测的精确度&#xff0c;还优化了模型训练流程&#xff0c;提升了效率和成本效益。超参数优化的新篇章&#xff1a;LSTM因其…

AWSLambda之设置时区

目标 希望Lambda运行的时区是东八区。 解决 只需要设置lambda的环境变量TZ为东八区时区即可&#xff0c;即Asia/Shanghai。 参考 使用 Lambda 环境变量

RAG系统向量数据库选型与Prompt Engineering鲁棒性测试实践

引言 在AI应用不断落地的今天&#xff0c;RAG&#xff08;Retrieval-Augmented Generation&#xff0c;检索增强生成&#xff09;和Prompt Engineering&#xff08;提示工程&#xff09;成为大模型工程师和测试工程师的核心武器。 一方面&#xff0c;RAG系统依赖强大的向量数据…

2.Socket 编程 UDP

1.UDP网络编程 0.背景知识 自实现IP转化 相关函数理解 IP相关理解 1. V2版本 - DictServer封装版 实现一个简单的英译汉的网络字典 Dict.hpp dictionary.txt InetAddr.hpp • 在 InetAddr 中&#xff0c;重载一下方便对用户是否是同一个进行比较 Log.hpp makefile Mutex.hpp…

数据可视化交互

目录 【实验目的】 【实验原理】 【实验环境】 【实验步骤】 一、安装 pyecharts 二、下载数据 三、实验任务 实验 1&#xff1a;AQI 横向对比条形图 代码说明&#xff1a; 运行结果&#xff1a; 实验 2&#xff1a;AQI 等级分布饼图 实验 3&#xff1a;多城市 AQI…

【MATLAB去噪算法】基于CEEMDAN联合小波阈值去噪算法(第四期)

CEEMDAN联合小波阈值去噪算法相关文献 一、EMD 与 EEMD 的局限性 &#xff08;1&#xff09;EMD (经验模态分解) 旨在自适应地将非线性、非平稳信号分解成一系列 本征模态函数 (IMFs)&#xff0c;这些 IMFs 从高频到低频排列。 核心问题&#xff1a;模态混合 (Mode Mixing) 同…

大话软工笔记—架构模型

1. 架构模型1—拓扑图 &#xff08;1&#xff09;拓扑图概念 拓扑图&#xff0c;将多个软件系统用网络图连接起来的表达方式。 &#xff08;2&#xff09;拓扑图分类 总线型结构 比较普遍采用的方式&#xff0c;将所有的系统接到一条总线上。 星状结构 各个系统通过点到…

24-Oracle 23 ai ​Lock-Free Reservations​(无锁列值保留)

数据库领域为了解决ACID的平衡&#xff0c;尝试了各种锁、各种模式&#xff0c; 引擎技术特性、厂家实现方式各放异彩&#xff0c;被各种锁折磨的小伙伴&#xff0c;是不是感同身受。 一、数据库锁 1. 锁的类型与特点 ​全局锁​&#xff1a;锁定整个数据库实例&#xff0c;备…

OpenPrompt 和直接对提示词的嵌入向量进行训练有什么区别

OpenPrompt 和直接对提示词的嵌入向量进行训练有什么区别 直接训练提示词嵌入向量的核心区别 您提到的代码: prompt_embedding = initial_embedding.clone().requires_grad_(True) optimizer = torch.optim.Adam([prompt_embedding

从零写一个ALSA声卡驱动学习(1)

前言&#xff1a; 本文档描述了如何编写 ALSA&#xff08;高级 Linux 音频架构&#xff09;驱动程序。文档主要聚焦于 PCI 声卡的实现。对于其他类型的设备&#xff0c;可能会使用不同的 API。不过&#xff0c;至少 ALSA 的内核 API 是一致的&#xff0c;因此本文档在编写这些驱…

链结构与工作量证明7️⃣:用 Go 实现比特币的核心机制

链结构与工作量证明:用 Go 实现比特币的核心机制 如果你用 Go 写过区块、算过哈希,也大致理解了非对称加密、数据序列化这些“硬核知识”,那么恭喜你,现在我们终于可以把这些拼成一条完整的“区块链”。 不过别急,这一节我们重点搞懂两件事: 区块之间是怎么连接成“链”…

深入理解 React 样式方案

React 的样式方案较多,在应用开发初期,开发者需要根据项目业务具体情况选择对应样式方案。React 样式方案主要有: 1. 内联样式 2. module css 3. css in js 4. tailwind css 这些方案中,均有各自的优势和缺点。 1. 方案优劣势 1. 内联样式: 简单直观,适合动态样式和…

YOLO电力物目标检测训练

最近需要进行电力物检测相关的业务&#xff0c;因此制作了一个电力物数据集&#xff0c;使用YOLO目标检测方法进行实验&#xff0c;记录实验过程如下&#xff1a; 数据集标注 首先需要对电力物相关设备进行标注&#xff0c;这里我们选用labelme进行标注&#xff0c;使用无人机…

从阿里云域名解析异常事件看下域名解析过程

近日阿里云核心域名aliyuncs.com解析异常&#xff0c;涉及众多依赖阿里云服务的网站和应用&#xff0c;故障从发现到修复耗时5个多小时。本文简要分析下整个事件的过程&#xff0c;并分析域名解析的过程&#xff0c;了解根域名服务器在其中的作用&#xff0c;以了解。 1、aliyu…