真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

使用React代碼動態(tài)生成柵格布局的方法

這篇文章主要講解了使用React代碼動態(tài)生成柵格布局的方法,內(nèi)容清晰明了,對此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會有幫助。

創(chuàng)新互聯(lián)專注于莎車網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗。 熱誠為您提供莎車營銷型網(wǎng)站建設(shè),莎車網(wǎng)站制作、莎車網(wǎng)頁設(shè)計、莎車網(wǎng)站官網(wǎng)定制、成都小程序開發(fā)服務(wù),打造莎車網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供莎車網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。

作為 TerminalMACS 的一個子進程模塊 - React Web管理端,使用Ant Design Pro作為框架。

本文應(yīng)用到的知識1.樣式文件less中方法的使用2.for循環(huán)創(chuàng)建按鈕和柵格布局(flex布局)

1. 最終效果

作為前端新手的我,做下面這個簡單功能花了好幾天時間,問了不少前端大佬(大佬們應(yīng)該要不到半個小時,慚愧慚愧),現(xiàn)在回想問的問題都很基礎(chǔ)(有點丟人,哈哈),多謝了哦。

先看看效果

使用React代碼動態(tài)生成柵格布局的方法

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 {
 constructor(props: Readonly<{}>) {
  super(props);
  this.state = {
   cardCount: 1,
  };
 }

 // 動態(tài)生成Grid
 createCard() {
  var res = [];
  for (var i = 0; i < this.state.cardCount * this.state.cardCount; i++) {
   res.push();
  }
  return res;
 }

 // 動態(tài)生成控制按鈕
 createControlButon() {
  var res = [];
  const btnCount = 4;
  for (let i = 1; i <= btnCount; i++) {
   res.push(
    ,
   );
  }

  return res;
 }

 // 修改顯示的格子數(shù)
 changeCardCount(count: any) {
  this.setState({
   cardCount: count,
  });
 }

 render() {
  return (
   
{this.createCard()}
{this.createControlButon()}
); } } export default VideoPanel;

代碼不多,for循環(huán)生成控制按鈕及柵格(未使用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 生成的每個柵格的樣式格式類似,只是長、寬比例區(qū)別,定義了方法(.video_panel(@count)),這是less的語法,極大的擴展了css功能,非常方便。

3. 關(guān)于TerminalMACS及本React Web管理端

3.1. TermainMACS

多終端資源管理與檢測系統(tǒng)(后續(xù)可能轉(zhuǎn)而寫成博客系統(tǒng)),包含多個子進程模塊,目前開發(fā)了Xamarin.Forms客戶端、WPF管理端、React Web管理端、.NET Core WEB API服務(wù)端,下一步繼續(xù)完善WPF管理端(IdentityServer 4研究中)。

3.2. React Web管理端

作為TerminalMACS系統(tǒng)的一個子進程模塊,目前使用 Ant Design Pro 搭建了框架,在平時工作中,添加一些測試Demo。

看完上述內(nèi)容,是不是對使用React代碼動態(tài)生成柵格布局的方法有進一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


新聞名稱:使用React代碼動態(tài)生成柵格布局的方法
本文地址:http://weahome.cn/article/podhhd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部