http://www.luidea.com/dedecms/jiaocheng/2910.html
dede:channelartlist获取指定的栏目列表
我们平时调用指定栏目列表的时候,channel标签虽然能调用栏目列表,但是不能调用指定的某些栏目栏目,所以我们一般用dede:channelartlist标签来实现,然后指定typeid属性来调用多个栏目,用逗号“,”分隔。
但是调用指定栏目的时候,都是用的后台栏目指定的排序方式,但是只需要修改一小点东西,就可以实现按我们指定的typeid顺序进行排序。方法如下:
打开/include/taglib/channelartlist.lib.php, 找到$dsql->SetQuery("SELECT id,typename,typedir,isdefault,ispart,defaultname,namerule2,moresite,siteurl,sitepath FROM `idea_arctype` WHERE $tpsql ORDER BY sortrank ASC LIMIT $totalnum"); 处,修改成:
这样后台的修改就完成了,模板调用的时候,在channelartlist标签中,增加一个ordeby='typeid'就可以按typeid排序了,不指定的话,就按后台指定的排序:
测试代码
对比如下:
![dede:channelartlist获取指定的栏目列表]()
但是调用指定栏目的时候,都是用的后台栏目指定的排序方式,但是只需要修改一小点东西,就可以实现按我们指定的typeid顺序进行排序。方法如下:
打开/include/taglib/channelartlist.lib.php, 找到$dsql->SetQuery("SELECT id,typename,typedir,isdefault,ispart,defaultname,namerule2,moresite,siteurl,sitepath FROM `idea_arctype` WHERE $tpsql ORDER BY sortrank ASC LIMIT $totalnum"); 处,修改成:
1 |
if(preg_match('#,#', $typeid) && $orderby == 'typeid') { |
2 |
$tpsql .= " ORDER BY FIELD(id,$typeid) "; |
3 |
} else { |
4 |
$tosql .= ' ORDER BY sortrank ASC '; |
5 |
} |
6 |
7 |
$dsql->SetQuery("SELECT id,typename,typedir,isdefault,ispart,defaultname,namerule2,moresite,siteurl,sitepath |
8 |
FROM `idea_arctype` WHERE $tpsql LIMIT$totalnum"); |
这样后台的修改就完成了,模板调用的时候,在channelartlist标签中,增加一个ordeby='typeid'就可以按typeid排序了,不指定的话,就按后台指定的排序:
测试代码
1 |
{dede:channelartlist typeid='1,2,3,4,5'} |
2 |
{dede:field.typename/}<br/> |
3 |
{/dede:channelartlist} |
4 |
-------------------------------------------<br/> |
5 |
{dede:channelartlist typeid='4,5,2,1,3' orderby='typeid'} |
6 |
{dede:field.typename/}<br/> |
7 |
{/dede:channelartlist} |

delphi lazarus opengl
网页操作自动化, 图像分析破解,游戏开发