昨天在论坛上看到一个朋友说要重新排序推荐位时间 V9推荐位文章信息都多维数组存储
那么问题来了普通的排序是更本无法实现了 唯有写重新写一个类
/**
* 对查询结果集进行排序
* author winenrzyy qq75526510
*
* @access public
* @param array $list 查询结果
* @param string $field 排序的字段名
* @param string $sortby 排序类型 (asc正向排序 desc逆向排序 nat自然排序)
* @return array
*/
if (! function_exists('list_sort_by'))
{
function list_sort_by($list, $field, $sortby = 'asc')
{
if (is_array($list))
{
$refer = $resultSet = array();
foreach ($list as $i => $data)
{
$refer[$i] = &$data[$field];
}
switch ($sortby)
{
case 'asc': // 正向排序
asort($refer);
break;
case 'desc': // 逆向排序
arsort($refer);
break;
case 'nat': // 自然排序
natcasesort($refer);
break;
}
foreach ($refer as $key => $val)
{
$resultSet[] = &$list[$key];
}
return $resultSet;
}
return false;
}
}例子:
/** * 例子 * 求:根据二维数组的id键值降序排列(也就是id越大的排在越前)? */ $list = array( 0 => array( 'id' => 1, 'name' => '第一' ), 1 => array( 'id' => 3, 'name' => '第三' ), 2 => array( 'id' => 2, 'name' => '第二' ), 3 => array( 'id' => 4, 'name' => '第四' ), ); //解答 $new_list = list_sort_by($list, 'id', 'desc');
V9推荐位中例子如
{pc:content action="position" posid="12" num="10"}
<ul>
{php $data = list_sort_by($data, 'inputtime', 'asc');}
{loop $data $key $val}
<li> <a href="{$val['url']}">{$val['title']}</a></li>
{/loop}
</ul>
{/pc}
