在smarty中引用数组

时间:2011-06-24 19:39:16

标签: php mysql smarty

我试图通过我正在调用的函数

引用数组
$bio['results'] = $db->query(sprintf('SELECT * FROM `athlete_bio_results` WHERE `PersonID` = %d ORDER BY `athlete_bio_results`.`Type` DESC, `athlete_bio_results`.`Date` DESC;', $id));

    $smarty->assign(value($params, 'to', 'athlete'), $bio);

在我看来,我通过foreach循环引用了这个数组中的一些字段。

我如何引用此foreach循环之外的字段进行检查。例如,在foreach循环中,我可以使用{$ result.Type),这将在该字段下显示数据库中的所有内容。我想在foreach循环之前检查某种类型。我的问题是引用foreach循环之外的那段数据。我怎么做到这一点?谢谢!

{if $athlete.results['Type'] == 'National'} <---- This is not working for me.
    {foreach $athlete.results as $result}
        {$result.Date|substr:0:-6} 
        {$result.Event} - 
        {$result.Result}
            {if $result.Junior == 'no' || $result.Junior == ''}
            {else}
                {'(Jr. Div.)'}
            {/if}
        <br />
    {/foreach}
{/if}

修改

这是可行的代码

{foreach $athlete.results as $result}
    {if $result['Type'] == 'National'}
        {$result.Date|substr:0:-6} 
        {$result.Event} - 
        {$result.Result}
            {if $result.Junior == 'no' || $result.Junior == ''}
            {else}
                {'(Jr. Div.)'}
            {/if}
    <br />
    {/if}
{/foreach}  

感谢您的帮助,指导我找到合适的解决方案:)

1 个答案:

答案 0 :(得分:3)

由于您正在访问数组的第一个元素,请使用密钥[0]

{if $athlete.results[0]['Type'] == 'National'}

其实我不确定是否会奏效。如果不是,请尝试使用此语法。

{if $athlete.results[0].Type == 'National'}

修改 您是否应该检查foreach内的类型?

{foreach $athlete.results as $result}
  {* Check inside the loop... *}
  {if $result['Type'] == 'National'}
    {$result.Date|substr:0:-6} 
    {$result.Event} - 
    {$result.Result}
        {if $result.Junior == 'no' || $result.Junior == ''}
        {else}
            {'(Jr. Div.)'}
        {/if}
    <br />
  {/if}
{/foreach}