使用React代码动态生成栅格布局的方法
作为 terminalmacs 的一个子进程模块 - react web管理端,使用ant design pro作为框架。
本文应用到的知识1.样式文件less中方法的使用2.for循环创建按钮和栅格布局(flex布局)
1. 最终效果及源码链接
作为前端新手的我,做下面这个简单功能花了好几天时间,问了不少前端大佬(大佬们应该要不到半个小时,惭愧惭愧),现在回想问的问题都很基础(有点丢人,哈哈),多谢了哦。
先看看效果
点击浏览源码:开源项目对应源码
2. 代码简单讲解
2.1 typescript代码
./src/pages/grid/dynamicgridpage/index.tsx
import react from 'react'; import styles from './index.less'; import { button, card } from 'antd'; interface ivideopanelprops {} interface ivideopanelsate { cardcount: number; } class videopanel extends react.component<ivideopanelprops, ivideopanelsate> { constructor(props: readonly<{}>) { super(props); this.state = { cardcount: 1, }; } // 动态生成grid createcard() { var res = []; for (var i = 0; i < this.state.cardcount * this.state.cardcount; i++) { res.push(<card classname={styles['video_panel' + this.state.cardcount]} />); } return res; } // 动态生成控制按钮 createcontrolbuton() { var res = []; const btncount = 4; for (let i = 1; i <= btncount; i++) { res.push( <button key={i} classname={styles['control_button']} type="primary" onclick={() => { this.changecardcount(i); }} > {i + '*' + i} </button>, ); } return res; } // 修改显示的格子数 changecardcount(count: any) { this.setstate({ cardcount: count, }); } render() { return ( <div classname={styles.main}> <div classname={styles.main_child}> <div classname={styles.left}> <div classname={styles.left_top}></div> <div classname={styles.left_bottom}></div> </div> <div classname={styles.right}> <div classname={styles.right_top}>{this.createcard()}</div> <div classname={styles.right_bottom}>{this.createcontrolbuton()}</div> </div> </div> </div> ); } } export default videopanel;
代码不多,for循环生成控制按钮及栅格(未使用antd的grid布局,简单使用div布局,flex很香),简化了很多代码。
2.2 less样式文件
./src/pages/grid/dynamicgridpage/index.less
@import '~antd/es/style/themes/default.less'; .main { position: absolute; width: 100%; height: 100%; background: red; } @ptcwidth: 250px; @btnareaheight: 50px; @videopanelmargin: 5px; .main_child { display: flex; height: 100%; } .left { width: @ptcwidth; height: 100%; background: green; } .left_top { width: 100%; height: @ptcwidth; background: orange; } .left_bottom { width: 100%; height: calc(100% - @ptcwidth); background: #ccc; } .right { width: calc(100% - @ptcwidth); height: 100%; background: #f60; } .right_top { width: 100%; height: calc(100% - @btnareaheight); background: blue; display: flex; flex-wrap: wrap; } .right_bottom { width: 100%; height: @btnareaheight; background: #f90; } .control_button { margin: 2px; } .video_panel(@count) { width: calc(100% / @count - @videopanelmargin * 2); height: calc(100% / @count - @videopanelmargin * 2); margin: @videopanelmargin; } // 1*1 .video_panel1 { .video_panel(1); } // 2*2 .video_panel2 { .video_panel(2); } // 3*3 .video_panel3 { .video_panel(3); } // 4*4 .video_panel4 { .video_panel(4); }
1 * 1、2 * 2、3 * 3、4 * 4 生成的每个栅格的样式格式类似,只是长、宽比例区别,定义了方法(.video_panel(@count)),这是less的语法,极大的扩展了css功能,非常方便。
3. 关于terminalmacs及本react web管理端
3.1. termainmacs
多终端资源管理与检测系统(后续可能转而写成博客系统),包含多个子进程模块,目前开发了xamarin.forms客户端、wpf管理端、react web管理端、.net core web api服务端,下一步继续完善wpf管理端(identityserver 4研究中)。
3.2. react web管理端
作为terminalmacs系统的一个子进程模块,目前使用 ant design pro 搭建了框架,在平时工作中,添加一些测试demo。
4. 关于项目开源开源项目地址:https://github.com/dotnet9/terminalmacs
官方网站:
总结
到此这篇关于使用react代码动态生成栅格布局的方法的文章就介绍到这了,更多相关react 动态生成栅格布局内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!