拜托,很长一段时间我都没有成功找到解决这个(对我来说非常困难的)问题的方法,我非常感谢任何帮助:
1) 我有像这样的简单数组中的数据,没有问题:
$data = array(
array('id => 1', 'name' => 'Some name 1'),
array('id => 2', 'name' => 'Some name 2'),
array('id => 3', 'name' => 'Some name 3'),
...
);
2) 但我必须将上面显示的数据渲染成 HTML 结构,理论上非常类似于树结构,其中每个父节点最多有 4 个叶子,每个节点可以成为接下来 4 个子节点的父节点(对树深度没有任何限制)。
a) 因此,如果我的数组中只有 4 个项目,则在网站上呈现为:
<div class="group">
<div class="group"><a href="#">Item 1</a></div>
<div class="group"><a href="#">Item 2</a></div>
<div class="group"><a href="#">Item 3</a></div>
<div class="group"><a href="#">Item 4</a></div>
</div>
b) 如果有 5 个项目,它应该像这样呈现:
<div class="group">
<div class="group"><a href="#">Item 1</a></div>
<div class="group"><a href="#">Item 2</a></div>
<div class="group"><a href="#">Item 3</a></div>
<div class="group">
<div class="group"><a href="#">Item 4</a></div>
<div class="group"><a href="#">Item 5</a></div>
</div>
</div>
c) 如果有 6 个项目,它应该像这样呈现:
<div class="group">
<div class="group"><a href="#">Item 1</a></div>
<div class="group"><a href="#">Item 2</a></div>
<div class="group">
<div class="group"><a href="#">Item 3</a></div>
<div class="group"><a href="#">Item 4</a></div>
</div>
<div class="group">
<div class="group"><a href="#">Item 5</a></div>
<div class="group"><a href="#">Item 6</a></div>
</div>
</div>
d) 如果有 16 个项目,它应该像这样呈现:
<div class="group">
<div class="group">
<div class="group"><a href="#">Item 1</a></div>
<div class="group"><a href="#">Item 2</a></div>
<div class="group"><a href="#">Item 3</a></div>
<div class="group"><a href="#">Item 4</a></div>
</div>
<div class="group">
<div class="group"><a href="#">Item 5</a></div>
<div class="group"><a href="#">Item 6</a></div>
<div class="group"><a href="#">Item 7</a></div>
<div class="group"><a href="#">Item 8</a></div>
</div>
<div class="group">
<div class="group"><a href="#">Item 9</a></div>
<div class="group"><a href="#">Item 10</a></div>
<div class="group"><a href="#">Item 11</a></div>
<div class="group"><a href="#">Item 12</a></div>
</div>
<div class="group">
<div class="group"><a href="#">Item 13</a></div>
<div class="group"><a href="#">Item 14</a></div>
<div class="group"><a href="#">Item 15</a></div>
<div class="group"><a href="#">Item 16</a></div>
</div>
</div>
e) 如果有 21 个项目,它应该像这样呈现:
<div class="group">
<div class="group">
<div class="group"><a href="#">Item 1</a></div>
<div class="group"><a href="#">Item 2</a></div>
<div class="group"><a href="#">Item 3</a></div>
<div class="group">
<div class="group"><a href="#">Item 4</a></div>
<div class="group"><a href="#">Item 5</a></div>
</div>
</div>
<div class="group">
<div class="group"><a href="#">Item 6</a></div>
<div class="group"><a href="#">Item 7</a></div>
<div class="group"><a href="#">Item 8</a></div>
<div class="group">
<div class="group"><a href="#">Item 9</a></div>
<div class="group"><a href="#">Item 10</a></div>
</div>
</div>
<div class="group">
<div class="group"><a href="#">Item 11</a></div>
<div class="group"><a href="#">Item 12</a></div>
<div class="group"><a href="#">Item 13</a></div>
<div class="group">
<div class="group"><a href="#">Item 14</a></div>
<div class="group"><a href="#">Item 15</a></div>
</div>
</div>
<div class="group">
<div class="group"><a href="#">Item 16</a></div>
<div class="group"><a href="#">Item 17</a></div>
<div class="group"><a href="#">Item 18</a></div>
<div class="group">
<div class="group"><a href="#">Item 19</a></div>
<div class="group"><a href="#">Item 20</a></div>
<div class="group"><a href="#">Item 21</a></div>
</div>
</div>
</div>
以上示例是为全背景屏幕设计的,分为 4 个主要相等的区域,这 4 个区域内部最多也可以包含 4 个区域,每个区域还可以包含接下来的 4 个区域,依此类推。
如果以 4 为模的项目总摘要计数为 0,则网站上的宽度和高度区域将相同,但除此之外,有些区域更大,有些区域分成更多子区域,为此,上述 HTML 代码可以正常工作(在静态页面上测试得很好)。
所以我很难找到如何将简单的数组数据转换成某种结构,以便通过任何递归函数或其他东西处理,以呈现所需的结果。
但正如我所写,我没有成功,主要是因为每个新的子容器都应该从结构的最后一个开始创建,并为 4 个主要象限中的每个象限统一创建。
我来这里是为了帮助回答你的问题,如果你愿意帮助我的话:)
我知道要描述清楚它有点复杂......
最佳答案
这比我预期的要棘手一些,因为您想要分配元素的方式。但这应该可以解决问题。
arrangeGroups() 函数将创建一个嵌套数组,就像您描述的那样。创建一个将此数据呈现为嵌套 div 的函数应该没有问题。
我添加了一些设置代码来动态生成任意数量的数组条目。使测试更容易。
define('GROUP_SIZE', 4);
$things = array();
for($idx=1; $idx<=21; $idx++)
$things[] = array( 'id'=>$idx, 'name'=>"Some name $idx" );
$groups = arrangeGroups($things);
print_r($groups);
function arrangeGroups($items) {
$tempGroups = array();
$itemCount = count($items); // we use this a lot.
// The hardest part here is figuring out how many items go into each group.
// Build an array of how big each subgroup should be.
// Put all the remainder items at the end of the array.
// Six items divided into four groups will yield the array
// (1, 1, 2, 2)
$groupings = array_fill(0, GROUP_SIZE, intval($itemCount/GROUP_SIZE));
$remainder = $itemCount % GROUP_SIZE ;
for ($idx=$remainder; $idx>0; $idx--)
$groupings[GROUP_SIZE-$idx]++;
// now we just create slices of the array we were given, using $groupings as our guide
$offset = $idx = 0;
do {
$sliceSize = $groupings[$idx];
if ( $sliceSize == 1 )
$tempGroups[] = $items[$offset];
else if ( $sliceSize > 1 )
$tempGroups[] = arrangeGroups( array_slice($items, $offset, $sliceSize) );
$offset += $sliceSize;
$idx++;
} while ($idx < GROUP_SIZE);
return $tempGroups;
}
关于php - 将数组数据准备到另一个结构以使用某些规则呈现定义的 HTML 输出的算法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13211101/
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于
我正在尝试使用ruby和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我
我正在尝试设置一个puppet节点,但rubygems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由rubygems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h