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

使用vueuse在组件内复用模板

1. 安装vueusae

pnpm i @vueuse/core

2. 组件内复用模板

createReusableTemplatevueuse中的一个实用工具,用于在 Vue 3 中创建可重复使用的模板片段同时保持状态的独立性。这对于需要在多个组件中重复使用相同的结构和逻辑时非常有用。
因为这些可复用的代码片段很少,所以抽离成一个单独的组件会有些不必要,比如需要同一种逻辑结构的表单项等。

这里简单举了一个用createReusableTemplate复用模板与传值的栗子:

<template><DefineTemplate v-slot="{ title, content }"><!--定义可复用内容 --><h3>{{ title }}</h3><div class="block">{{ content }}</div></DefineTemplate><!- 第一处复用 --><ReuseTemplate title="标题1" content="复用内容1" /><span> ----------------------------</span><ReuseTemplate title="标题2" content="复用内容2" />
</template>
<script setup lang="ts">
import { createReusableTemplate } from "@vueuse/core";const [DefineTemplate, ReuseTemplate] = createReusableTemplate();
</script>
<style scoped>
.block {width: 150px;height: 150px;background-color: aliceblue;display: grid;place-items: center;font-size: 18px;
}
</style>

在这里插入图片描述

注意:

  1. <DefineTemplate>用于注册模板,但本身不渲染任何内容。
  2. <ReuseTemplate>则用来展示由<DefineTemplate>提供的模板。
  3. <DefineTemplate>必须在<ReuseTemplate>之前使用。

3. 使用场景

  1. 表单元素的复用: 如果你有一组表单元素(如输入框、下拉菜单等),并且这些元素在多个表单或多个组件中使用,createReusableTemplate 可以帮助你将这些表单元素封装为一个可复用的模板。

  2. 列表项的复用: 假设你有一个复杂的列表项结构,需要在多个地方使用,比如在主页的推荐列表和分类页的商品列表中。

  3. 弹窗内容的复用: 你可能需要在多个地方展示相同的弹窗内容,例如确认弹窗或表单弹窗。使用 createReusableTemplate,你可以确保弹窗的内容和逻辑只定义一次,但可以在多个地方复用。

  4. 可复用的布局结构: 如果你有一套通用的布局结构,例如卡片布局或者特定的网格布局,并且在多个组件中使用相同的结构,可以通过 createReusableTemplate 进行封装和复用。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Unity实现经验条动态自适应
  • 用Python实现时间序列模型实战——Day 3: 时间序列数据预处理
  • Windows 禁用tls 1.0 1.1
  • C语言的选择结构
  • 网络优化4|网络流问题|路径规划问题|车辆路径问题
  • 8月27日笔记
  • MySQL——子查询(5)带比较运算符的子查询
  • 基于springboot篮球竞赛预约平台设计与实现
  • 【Unity输入】Unity输入方式总结
  • Chrome H265 WebRTC 支持
  • NoSql数据库Redis集群
  • C++ | Leetcode C++题解之第376题摆动序列
  • 前端面试宝典【CSS篇】【10】
  • 永久去除windows11推荐产品的软件
  • OpenCV图像拼接多频段融合源码重构
  • Angular 响应式表单 基础例子
  • Git的一些常用操作
  • HTML中设置input等文本框为不可操作
  • java B2B2C 源码多租户电子商城系统-Kafka基本使用介绍
  • spark本地环境的搭建到运行第一个spark程序
  • 翻译:Hystrix - How To Use
  • 汉诺塔算法
  • 简析gRPC client 连接管理
  • 面试遇到的一些题
  • Spring第一个helloWorld
  • 阿里云API、SDK和CLI应用实践方案
  • 说说我为什么看好Spring Cloud Alibaba
  • ​【原创】基于SSM的酒店预约管理系统(酒店管理系统毕业设计)
  • ​io --- 处理流的核心工具​
  • #define 用法
  • $(selector).each()和$.each()的区别
  • (C#)一个最简单的链表类
  • (C语言)fread与fwrite详解
  • (function(){})()的分步解析
  • (Ruby)Ubuntu12.04安装Rails环境
  • (读书笔记)Javascript高级程序设计---ECMAScript基础
  • (二)【Jmeter】专栏实战项目靶场drupal部署
  • (机器学习-深度学习快速入门)第一章第一节:Python环境和数据分析
  • (六)vue-router+UI组件库
  • (顺序)容器的好伴侣 --- 容器适配器
  • (转)C#调用WebService 基础
  • (转)我也是一只IT小小鸟
  • .dwp和.webpart的区别
  • .NET gRPC 和RESTful简单对比
  • .NET MVC 验证码
  • .Net 高效开发之不可错过的实用工具
  • .Net+SQL Server企业应用性能优化笔记4——精确查找瓶颈
  • .netcore 获取appsettings
  • .NET框架
  • ??javascript里的变量问题
  • [ 常用工具篇 ] POC-bomber 漏洞检测工具安装及使用详解
  • [Ariticle] 厚黑之道 一 小狐狸听故事
  • [BZOJ] 2006: [NOI2010]超级钢琴
  • [C++] 小游戏 斗破苍穹 2.11.6 版本 zty出品
  • [CF494C]Helping People