正则匹配出所有的arclist标签并构造SQL
取出数据并替换field为相应字段的数据
为field标签添加一个function属性
$v)
{
// 取出标签相应的属性字符串并把属性转化成一个数组,如 row="10" channelid="17" addfields="pffz,pfrs,yuyan" orderby="id" orderway="desc"
$attrArr = strToArray($a[1][$k]);
// 根据构造构造SQL语句上的变量
if(isset($attrArr['row']))
$limit = $attrArr['row'];
else
$limit = 20;
if(isset($attrArr['orderby']))
$orderby = $attrArr['orderby'];
else
$orderby = 'id';
if(isset($attrArr['orderway']))
$orderway = $attrArr['orderway'];
else
$orderway = 'desc';
// 连表的属性
if(isset($attrArr['channelid']))
$leftJoin = ' LEFT JOIN dede_addon17 b ON a.id=b.aid ';
else
$leftJoin = '';
if(isset($attrArr['addfields']))
$extraFields = ','.$attrArr['addfields'];
else
$extraFields = '';
// 解析属性
$sql = "SELECt a.*$extraFields
FROM dede_archives a $leftJoin
ORDER BY $orderby $orderway
LIMIT $limit";
$dsql->Execute('me', $sql);
$html = '';
// 每个arclist对应的多个数据
while($row = $dsql->GetArray('me'))
{
// 重置模板字符串,不要在原模板上面进行替换
$_tep = $a[2][$k];
// 把字符串中的[field:xxxx/]替换成$row['xxxx']变量。
$_re = '/[field:(w+)(s+function=("|')(w+)((.*))3)?/]/U';
preg_match_all($_re, $_tep, $_a);
/**