【VUE】vue3 SFC方式实现九宫格效果

2023-11-11 08:11

本文主要是介绍【VUE】vue3 SFC方式实现九宫格效果,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

效果图

九宫格效果

调用方式

<template><grid class="grid-demo" isScale><grid-item class="grid-demo-item">1</bg-grid-item><grid-item class="grid-demo-item">2</bg-grid-item><grid-item class="grid-demo-item">3</bg-grid-item><grid-item class="grid-demo-item">4</bg-grid-item><grid-item class="grid-demo-item">5</bg-grid-item><grid-item class="grid-demo-item">6</bg-grid-item><grid-item class="grid-demo-item">7</bg-grid-item><grid-item class="grid-demo-item">8</bg-grid-item><grid-item class="grid-demo-item">9</bg-grid-item></grid>
<template><style scoped>
.grid-demo{background-color: #2b2d42;
}
.grid-demo-item{color: #fff;background-color: #41497D;
}
</style>

grid-item组件代码

<script setup>
import {ref, inject, watch} from 'vue'defineOptions({name: 'GridItem'
})
const isScale = inject("isScale");// 自适应高度等于宽度
const liDom = ref();
const height = ref("");
watch(() => liDom.value, (dom) => {if (isScale) {height.value = dom.clientWidth + "px";} else {height.value = "";}
}, {deep: true,
});</script><template><li class="grid-layout-item" ref="liDom"><slot /></li>
</template><style scoped lang="scss">
.grid-layout-item {float: left;list-style: none;height: v-bind(height);line-height: v-bind(height);text-align: center;vertical-align: middle;margin-bottom: 10px;
}
</style>

grid组件代码

<script setup>
import {useSlots, provide, ref, computed, watch, onMounted} from "vue";defineOptions({name: "Grid"
})
const props = defineProps({/** 间隔 */gutter: {type: Number, default: 10},/** 列数 */column: {type: Number, default: 3},/** 约束宽=高 */isScale: {type: Boolean, default: false},
})provide('isScale', props.isScale)
// 插槽列表
const slotList = useSlots()?.default() || []
// 渲染列表
const renderList = ref([])
const columnNum = ref(props.column || 1)
// 尾行编号
const lastRow = ref(0);const gridStyles = computed(() => {return {overflow: "hidden",padding: `${props.gutter}px`,margin: "0px"}
})function _SlotListHandler(el, index) {if (typeof el.type === "object" && el.type.name === "GridItem") {if (!el.props) el.props = {};if (!el.props.style) el.props.style = {};el.props.style.width = `calc((100% - ${props.gutter * (columnNum.value - 1)}px) / ${columnNum.value})`;// 右边距设置和下边距设置el.props.style.marginRight = `${props.gutter}px`;el.props.style.marginBottom = `${props.gutter}px`;// 每行最后一个不加右边距if ((index + 1) % columnNum.value === 0) el.props.style.marginRight = "0px";// 最后一行不加下边距if ((index + 1) >= lastRow.value * columnNum.value){el.props.style.marginBottom = 0;}else{el.props.style.marginBottom = `${props.gutter}px`}return el;} else if (typeof el.type === 'symbol') {let _list = [];el.children.forEach((childrenEl, childrenIndex) => {_list.push(_SlotListHandler(childrenEl, childrenIndex));})return _list;}return false;
}function renderSlot(list) {renderList.value = [];lastRow.value = Math.ceil((list[0]?.children||[]).length / columnNum.value) - 1;list.forEach((el, index) => {let _e = _SlotListHandler(el, index);if (_e instanceof Array) {renderList.value.push(..._e);} else if (typeof _e === 'object') {renderList.value.push(_e);}});
}watch(() => slotList,(list) => {console.log('list:', list)renderSlot(list);},{deep: true}
)onMounted(()=>{renderSlot(slotList);
})
</script><template><div class="grid-layout"><ul :style="gridStyles"><component v-for="(element, key) in renderList" :key="key":is="element"/></ul></div>
</template><style scoped lang="scss">
.grid-layout {list-style: none;
}
</style>

这篇关于【VUE】vue3 SFC方式实现九宫格效果的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u

Jenkins分布式集群配置方式

《Jenkins分布式集群配置方式》:本文主要介绍Jenkins分布式集群配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装jenkins2.配置集群总结Jenkins是一个开源项目,它提供了一个容易使用的持续集成系统,并且提供了大量的plugin满

c++ 类成员变量默认初始值的实现

《c++类成员变量默认初始值的实现》本文主要介绍了c++类成员变量默认初始值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录C++类成员变量初始化c++类的变量的初始化在C++中,如果使用类成员变量时未给定其初始值,那么它将被

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys