> 백엔드 개발 > PHP 튜토리얼 > 求高手给一个Metro风格布局

求高手给一个Metro风格布局

WBOY
풀어 주다: 2016-06-23 13:44:42
원래의
1094명이 탐색했습니다.

用table,初始表格共3行6列
单元格三种规格:1x1  2x1  2x2 ,随机
如下图所示:

谢谢!


回复讨论(解决方案)

这个意思?

<table border=1 style='width:100%; table-layout:fixed;'><tr><th colspan=2>我是标题</th><th rowspan=2 colspan=2>我是标题</th><th colspan=2>我是标题</th></tr><tr><th rowspan=2  colspan=2>我是标题</th><th>我是标题</th><th>我是标题</th></tr><tr><th colspan=2>我是标题</th><th colspan=2>我是标题</th></tr></table>
로그인 후 복사

用css+div 可能要简单些

这个意思?
用css+div 可能要简单些


简短的html静态语言我会,我要用php实现随机的。

单元格(三种规格:1x1 2x1 2x2 )需要随机出现

给你个思路,自己调整去吧

$ar = array(  array('1x2', '我是标题'),  array('2x2', '我是标题'),  array('1x2', '我是标题'),  array('2x2', '我是标题'),  array('1x1', '我是标题'),  array('1x1', '我是标题'),  array('1x2', '我是标题'),  array('1x2', '我是标题'),  array('2x2', '我是标题'),  array('2x2', '我是标题'),  array('1x1', '我是标题'),  array('1x1', '我是标题'),  array('1x1', '我是标题'),  array('1x1', '我是标题'),);shuffle($ar);$box = array(  array(1, 1, 1, 1, 1, 1),  array(1, 1, 1, 1, 1, 1),  array(1, 1, 1, 1, 1, 1),);$res = array();foreach($ar as $ind=>$item) {  list($h, $w) = explode('x', $item[0]);  //从左上角开始查找摆放的位置  $flag = 0;  for($y=0; $y<count($box); $y++) {    for($x=0; $x<count($box[$y]); $x++) {      if($box[$y][$x] == 1 && isset($box[$y+$h-1][$x+$w-1]) && $box[$y+$h-1][$x+$w-1] == 1) {        $flag++;        break 2;      }    }  }  if($flag) {    $res[$y][] = array('c' => $w, 'r' => $h, 'v' => $ind);    for($i=0; $i<$h; $i++) {      for($j=0; $j<$w; $j++) {        $box[$y+$i][$x+$j] = 0;      }    }  }}echo "<table border=1 style='width:100%; table-layout:fixed;'>";foreach($res as $row) {  echo '<tr>';  foreach($row as $cell) {    echo "<th colspan=$cell[c] rowspan=$cell[r]>{$ar[$cell['v']][1]}</th>";  }  echo '</tr>';}echo "</table>";
로그인 후 복사

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿