css display:grid布局,实现任意行、列合并后展示,自适应大小屏幕

现有6X7列的一个布局,如下图所示

想要用户能组成任意矩形盒子,并展示内容,具体效果如下(仅为一个示例,其实可以任意组合矩形):

html代码:

html 复制代码
<div class="grid-container">
	<div class="grid-item"  
		v-for="(v,k) in boxList" 
		:key="k"
		:style="getStyle(v)"
	>{{v.num}}</div>
</div>

首先循环出42个格子,js代码

typescript 复制代码
getData() {
	// 指定每行最大的元素数量
	const maxPerRow = 6;
	// 循环生成 42 个元素
	for (let i = 1; i <= 42; i++) {
		// 计算当前元素所在的行和列
		let row = Math.ceil(i / maxPerRow);
		let col = i % maxPerRow === 0 ? maxPerRow : i % maxPerRow;
		let data = {
			num: i,
			x: [row, col],
			merge: [0, 0],//[合并行数,合并列数]
		};
		// 添加对象到数组
		this.boxList.push(data);
	}
},

此时会生成如图1所示的42个格子,让用户去勾选格子合并,合并逻辑后端完成。

样式合并方法如下:

typescript 复制代码
getStyle(v) {
	const styles = {};
		if (v.merge[0] > 0) {//合并列
			styles['grid-row'] = `${v.x[0]} / span ${v.merge[0]}`;
		}
		if (v.merge[1] > 0) {//合并行
			styles['grid-column'] = `${v.x[1]} / span ${v.merge[1]}`;
		}
		return styles;
	},

模拟后端数据返回方法如下:

bash 复制代码
getData() {
	// 指定每行最大的元素数量
	const maxPerRow = 6;

	// 循环生成 42 个元素
	for (let i = 1; i <= 42; i++) {
		// 计算当前元素所在的行和列
		let row = Math.ceil(i / maxPerRow);
		let col = i % maxPerRow === 0 ? maxPerRow : i % maxPerRow;
		let data = {
			num: i,
			x: [row, col],
			merge: [0, 0],//[合并行数,合并列数]
		};
		if(i == 3) {
			data.merge = [3, 2];
		}
		if(i == 5) {
			data.merge = [3, 2];
		}
		if([19,21,31,33,35].indexOf(i) > -1) {
			data.merge = [2, 2];
		}
		if([23,24].indexOf(i) > -1) {
			data.merge = [2, 0];
		}
		// 添加对象到数组
		if([4,6,9,10,11,12,15,16,17,18,20,22,25,26,27,28,29,30,32,34,36,37,38,39,40,41,42].indexOf(i) == -1) {
			this.boxList.push(data);
		}
	}
},

生成效果为:

相关推荐
lbh7 小时前
当我开始像写代码一样和AI对话,一切都变了
前端·openai·ai编程
We་ct8 小时前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·数据结构·算法·leetcode·typescript·动态规划·取反
qq_406176148 小时前
深入浅出 Pinia:Vue3 时代的状态管理新选择
javascript·vue.js·ecmascript
wefly20179 小时前
m3u8live.cn 在线M3U8播放器,免安装高效验流排错
前端·后端·python·音视频·前端开发工具
C澒9 小时前
微前端容器标准化 —— 公共能力篇:通用打印
前端·架构
德育处主任Pro9 小时前
前端元素转图片,dom-to-image-more入门教程
前端·javascript·vue.js
木斯佳9 小时前
前端八股文面经大全:小红书前端一二面OC(下)·(2026-03-17)·面经深度解析
前端·vue3·proxy·八股·响应式
陈天伟教授10 小时前
人工智能应用- 预测新冠病毒传染性:04. 中国:强力措施遏制疫情
前端·人工智能·安全·xss·csrf
zayzy10 小时前
前端八股总结
开发语言·前端·javascript
今天减肥吗10 小时前
前端面试题
开发语言·前端·javascript