找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 428|回复: 0
打印 上一主题 下一主题

dedecms按栏目名首字母/数字排序输出的实现方法

[复制链接]

2588

主题

2588

帖子

7694

积分

论坛元老

Rank: 8Rank: 8

积分
7694
跳转到指定楼层
楼主
发表于 2018-2-13 20:40:15 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

我们先测试一下读取子类
复制代码代码如下:
SELECT substr(typename,1,1) FROM `dede_arctype` WHERE topid>0
好了现在正式开始增加字段
增加字段如图

取第一个给刚加的字段 first_l
复制代码代码如下:
update `dede_arctype` set first_word=substr( typename,1,1)
复制代码代码如下:
function getfristword( $tid )
{
$str ='';
$tid = intval( $tid );
$dsql = new Dedesql(false);
$sql ="select `first_word` from dede_arctype where topid='$tid' group by first_word";
$dsql->SetQuery($sql);
$dsql->Execute('hw');
while($row=$dsql->GetArray('hw'))
{
if($row['first_word'])
{
$wd =$row['first_word'];
$sql = "select * from dede_arctype where topid=$tid and first_word= '$wd' ";
$dsql->SetQuery($sql);
$dsql->Execute('wd');
$str .=''.strtoupper($wd).'开头';
while( $rs = $dsql->GetArray('wd') )
{
$str .='[url='.str_replace('{cmspath}','',$rs['typedir']).']'.$rs['typename'].'[/url]';
}
}
}
return $str;
}
写好后,我们找到调用栏目的模板
jx.html里面这样写
复制代码代码如下:
{dede:field.id function="getfristword(@me)"/} 这里是讲把当前栏目的id给getfirestword();
提示影响了 420 行。 ( 查询花费 0.0176 秒 ) 代码成功了,现在查看
如图

现在打开 dedecms的/include/channelunit.func.php文件,我们在这里增加自定义函数
好了我们的效果就出来了如图

好了看看最终效果
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

用户反馈
客户端