多行文本的文字展示全部和收起功能

2024-06-19 05:52

本文主要是介绍多行文本的文字展示全部和收起功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

组件代码:

<template><!-- 外层容器,使用相对定位 --><div class="relative"><!-- 文本容器,根据 expanded 状态决定是否应用 line-clamp-4--><div :class="{ 'line-clamp-4': !expanded }" ref="textContainer">{{ text }}</div><!-- 展开/收起按钮,只有在文本需要折叠时才显示,使用绝对定位 --><buttonv-if="isCollapsible"@click="toggleExpand"class="text-blue-500 absolute -right-6 bottom-0">{{ expanded ? '收起' : '展开' }}</button></div>
</template><script setup>
import { ref, onMounted, nextTick } from 'vue'// 定义组件的 props
const props = defineProps({text: {type: String,required: true},fontSize: {type: String,required: false,default: '12px'}
})const expanded = ref(false)  // 控制文本是否展开
const isCollapsible = ref(false)  // 控制文本是否需要折叠
const textContainer = ref(null)  // 引用文本容器// 切换展开/收起状态的函数
const toggleExpand = () => {expanded.value = !expanded.value
}// 检查文本是否需要折叠的函数
const checkCollapsible = () => {nextTick(() => {const width = textContainer.value.clientWidth  // 获取文本容器的宽度const dummyElement = document.createElement('div')dummyElement.style.position = 'absolute'dummyElement.style.visibility = 'hidden'dummyElement.style.width = `${width}px`dummyElement.style.fontSize = props.fontSize  // 设置字体大小dummyElement.style.lineHeight = getComputedStyle(textContainer.value).lineHeightdummyElement.innerText = props.textdocument.body.appendChild(dummyElement)const lineHeight = parseInt(getComputedStyle(dummyElement).lineHeight)  // 获取行高const totalHeight = dummyElement.clientHeight  // 获取文本总高度document.body.removeChild(dummyElement)const maxHeight = lineHeight * 4 + 5  // 设定最大高度(假设最多显示4行)isCollapsible.value = totalHeight > maxHeight  // 判断是否需要折叠})
}// 组件挂载时执行的操作
onMounted(() => {checkCollapsible()  // 检查文本是否需要折叠window.addEventListener('resize', checkCollapsible)  // 监听窗口大小变化,重新检查
})
</script><style scoped>
</style>

效果图:
在这里插入图片描述
在这里插入图片描述
优化版本,展开全部文字 展示在文本域后面。需要做一个截取文本操作。

<template><div><div ref="textContainer" :class="{ 'line-clamp-4': !expanded }"><span v-if="!expanded">{{ truncatedText }}</span><span v-else>{{ text }}</span><button v-if="isCollapsible" @click="toggleExpand" class="text-blue-500 ml-2">{{ expanded ? '收起' : '展开全部' }}</button></div></div>
</template><script setup>
import { ref, onMounted, nextTick } from 'vue'// 定义组件的 props
const props = defineProps({text: {type: String,required: true},fontSize: {type: String,required: false,default: '12px'},targetLines: {type: Number,required: false,default: 4}
})// 定义响应式变量
const expanded = ref(false)  // 控制文本是否展开
const isCollapsible = ref(false)  // 控制文本是否需要折叠
const textContainer = ref(null)  // 引用文本容器
const truncatedText = ref('')  // 存储截断的文本// 切换展开/收起状态的函数
const toggleExpand = () => {expanded.value = !expanded.value
}// 检查文本是否需要折叠的函数
const checkCollapsible = () => {nextTick(() => {const width = textContainer.value.clientWidthconst dummyElement = document.createElement('div')dummyElement.style.position = 'absolute'dummyElement.style.visibility = 'hidden'dummyElement.style.width = `${width}px`dummyElement.style.fontSize = props.fontSize  // 设置字体大小dummyElement.style.lineHeight = getComputedStyle(textContainer.value).lineHeightdummyElement.style.whiteSpace = 'pre-wrap'dummyElement.style.wordWrap = 'break-word'dummyElement.innerText = props.textdocument.body.appendChild(dummyElement)const lineHeight = parseInt(getComputedStyle(dummyElement).lineHeight)  // 获取行高const maxHeight = lineHeight * props.targetLines  // 设定最大高度isCollapsible.value = dummyElement.clientHeight > maxHeight  // 判断是否需要折叠if (isCollapsible.value) {// 截断文本以适应最大高度let totalHeight = 0let truncated = ''const words = props.text.split(' ')for (let i = 0; i < words.length; i++) {const word = words[i]dummyElement.innerText = truncated + word + ' ' + '... 展示全部'if (dummyElement.clientHeight > maxHeight) breaktruncated += word + ' '}truncatedText.value = truncated.trimEnd() + '...'} else {truncatedText.value = props.text}document.body.removeChild(dummyElement)})
}// 组件挂载时执行的操作
onMounted(() => {checkCollapsible()  // 检查文本是否需要折叠window.addEventListener('resize', checkCollapsible)  // 监听窗口大小变化,重新检查
})
</script><style scoped></style>

效果图:
在这里插入图片描述
在这里插入图片描述

这篇关于多行文本的文字展示全部和收起功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1074191

相关文章

SpringBoot整合DeepSeek实现AI对话功能

《SpringBoot整合DeepSeek实现AI对话功能》本文介绍了如何在SpringBoot项目中整合DeepSeekAPI和本地私有化部署DeepSeekR1模型,通过SpringAI框架简化了... 目录Spring AI版本依赖整合DeepSeek API key整合本地化部署的DeepSeek

Python实现多路视频多窗口播放功能

《Python实现多路视频多窗口播放功能》这篇文章主要为大家详细介绍了Python实现多路视频多窗口播放功能的相关知识,文中的示例代码讲解详细,有需要的小伙伴可以跟随小编一起学习一下... 目录一、python实现多路视频播放功能二、代码实现三、打包代码实现总结一、python实现多路视频播放功能服务端开

C#使用DeepSeek API实现自然语言处理,文本分类和情感分析

《C#使用DeepSeekAPI实现自然语言处理,文本分类和情感分析》在C#中使用DeepSeekAPI可以实现多种功能,例如自然语言处理、文本分类、情感分析等,本文主要为大家介绍了具体实现步骤,... 目录准备工作文本生成文本分类问答系统代码生成翻译功能文本摘要文本校对图像描述生成总结在C#中使用Deep

css实现图片旋转功能

《css实现图片旋转功能》:本文主要介绍了四种CSS变换效果:图片旋转90度、水平翻转、垂直翻转,并附带了相应的代码示例,详细内容请阅读本文,希望能对你有所帮助... 一 css实现图片旋转90度.icon{ -moz-transform:rotate(-90deg); -webkit-transfo

Java实现Elasticsearch查询当前索引全部数据的完整代码

《Java实现Elasticsearch查询当前索引全部数据的完整代码》:本文主要介绍如何在Java中实现查询Elasticsearch索引中指定条件下的全部数据,通过设置滚动查询参数(scrol... 目录需求背景通常情况Java 实现查询 Elasticsearch 全部数据写在最后需求背景通常情况下

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

Java中使用Java Mail实现邮件服务功能示例

《Java中使用JavaMail实现邮件服务功能示例》:本文主要介绍Java中使用JavaMail实现邮件服务功能的相关资料,文章还提供了一个发送邮件的示例代码,包括创建参数类、邮件类和执行结... 目录前言一、历史背景二编程、pom依赖三、API说明(一)Session (会话)(二)Message编程客

Java CompletableFuture如何实现超时功能

《JavaCompletableFuture如何实现超时功能》:本文主要介绍实现超时功能的基本思路以及CompletableFuture(之后简称CF)是如何通过代码实现超时功能的,需要的... 目录基本思路CompletableFuture 的实现1. 基本实现流程2. 静态条件分析3. 内存泄露 bug

C#实现系统信息监控与获取功能

《C#实现系统信息监控与获取功能》在C#开发的众多应用场景中,获取系统信息以及监控用户操作有着广泛的用途,比如在系统性能优化工具中,需要实时读取CPU、GPU资源信息,本文将详细介绍如何使用C#来实现... 目录前言一、C# 监控键盘1. 原理与实现思路2. 代码实现二、读取 CPU、GPU 资源信息1.

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf