我正在尝试显示一个表格,该表格显示了不同的会员资格包,并且需要尝试将每列替换颜色来分隔包。我有交替单元格的代码,但它们是水平而不是垂直的。如果可能的话,请告诉我,如果我的代码错误,请垂直交替单元格。谢谢
<table width="100%" border="0" cellspacing="0">
<tr>
<td> </td>
<?php
foreach((array) $membership_names as $name) { ?>
<td align="center" style="background:#ffffe4; padding:5px; border-top:1px solid #ccc; border-right:1px solid #fff; border-left:1px solid #fff;"><strong><?php echo $this->escape($name); ?></strong></td>
<?php } ?>
</tr>
<?php
$i = 1; // Our row counter
foreach((array) $memberships as $membership) {
if ($i % 2 != 0) # An odd row
$rowStyle = "background:#FFFFE4; border-bottom:1px solid #ccc; border-top:1px solid #fff; height:40px; padding:10px;";
else # An even row
$rowStyle = "background:#FFF4D8; border-bottom:1px solid #ccc; border-top:1px solid #fff; height:40px; padding:10px;";
?>
<tr>
<td align="left" style="<?php echo $rowStyle; ?>"><strong><?php echo $this->escape($membership['title']); ?>:</strong></td>
<?php foreach((array) $membership['values'] as $value) {
if ($i % 2 != 0) # An odd row
$rowStyle = "background:#FFFFE4; border-bottom:1px solid #ccc; border-top:1px solid #fff; height:40px; padding:10px;";
else # An even row
$rowStyle = "background:#FFF4D8; border-bottom:1px solid #ccc; border-top:1px solid #fff; height:40px; padding:10px;";
?>
<td align="center" style="<?php echo $rowStyle; ?>">
<?php if($value == 'yes') { ?>
<img src="<?php echo BASE_URL.TEMPLATE_PATH; ?>images/icon_checkmark.gif" />
<?php } elseif($value == '-') {?>
<img src="<?php echo BASE_URL.TEMPLATE_PATH; ?>images/icon_checkno.gif" />
<?php } elseif($value == '0') {?>
<img src="<?php echo BASE_URL.TEMPLATE_PATH; ?>images/icon_checkno.gif" />
<?php } else { ?>
<?php echo $this->escape($value); ?>
<?php } ?>
</td>
<?php } ?>
</tr>
<?php
$i++; # Increment our row counter
}
?>
<tr>
<td align="left" valign="top" style="background:#9C6C69; color: #FFFFE4; border-bottom:1px solid #ccc; border-top:1px solid #fff; font-weight:bold; height:40px; padding:10px;"> </td>
<?php foreach((array) $pricing as $price) { ?>
<td align="center" valign="top" style="background:#9C6C69; border-bottom:1px solid #ccc; border-top:1px solid #fff; color: #FFFFE4; height:40px; padding:10px;">
<?php foreach($price['pricing'] as $key=>$value) { ?>
<?php if(count($price['pricing']) > 1) { ?><p><strong><?php echo $lang['public_compare_option']; ?> <?php echo $key+1; ?></strong></p><?php } ?>
<?php if($value['label']) { ?>
<p style="font-size:11px;"><?php echo $this->escape($value['label']); ?></p>
<?php } else { ?>
<?php //echo $lang['public_compare_term']; ?>
<?php if($value['period_count']) { ?>
<p style="font-size:11px; font-weight:bold;"><?php echo $this->escape($value['period_count']); ?> <?php echo $this->escape($value['period']); ?></p>
<?php } else { ?>
<p><?php echo $lang['public_compare_lifetime']; ?></p>
<?php } ?>
<?php if($value['setup_price'] != '0.00') { ?>
<p><?php echo $lang['public_compare_setup']; ?>: <?php echo $this->escape(format_number_currency($value['setup_price'])); ?></p>
<?php } ?>
<?php //echo $lang['public_compare_price']; ?>
<?php if($value['price'] != '0.00') { ?>
<p style="border-bottom: 1px dashed #FFFFFF; border-top: 1px dashed #FFFFFF; font-size: 14px; font-weight: bold; margin-top: 2px; padding: 2px;">$<?php echo $this->escape($value['price']); ?></p>
<?php } else { ?>
<p style="border-bottom: 1px dashed #FFFFFF; border-top: 1px dashed #FFFFFF; font-size: 14px; font-weight: bold; margin-top: 2px; padding: 2px;"><?php echo $lang['public_compare_free']; ?></p>
<?php } ?>
<?php } ?>
<p><a href="<?php echo BASE_URL.MEMBERS_FOLDER; ?>user_orders_add_listing.php?pricing_id=<?php echo $value['id']; ?>" class="ui-button ui-widget ui-state-default ui-corner-all ui-button-text-only" style="margin-top:3px;padding:5px;"><?php echo $lang['public_compare_order']; ?></a></p>
<?php } ?>
</td>
<?php } ?>
</tr>
</table>
答案 0 :(得分:1)
确定裂缝指关节,让我们试试这个: 从foreach语句中删除(数组),您不需要它。另外,$ i%2!= 0,你不需要全部,只需使用$ i%2,它是真还是假,所以如果($ i%2)将是真或假,你不要不需要!= 0.而不是有两个不同的$ rowstyles,只需要在你的CSS中设置2个,并使用php short if if选择要使用的那个,比如这个
($i %2 ? 'style1' : 'style2')
将它放在你的表格单元格中:
<td style="($i %2 ? 'style1' : 'style2')">
根据您的$ i是偶数还是奇数,这将替换样式。 您还需要确保$ i在每行的开头重置为0,因为您是交替列颜色,您希望所有行都以0开头,以便它们正确排列。您不需要使用$ i跟踪行,因为您不关心它们是什么颜色而只关心列,只需确保每次启动新表行时将$ i重置为0。 / p>
答案 1 :(得分:0)
您在两个嵌套循环中使用$i
两次,这将失败。还要尝试在第二个foreach
循环之前重置它。