昨天在论坛上看到一个朋友说要重新排序推荐位时间 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}