如何在织梦栏目管理里面自定义选项字段

如何在织梦栏目管理里面自定义选项字段,第1张

以前我在织梦论坛发过这样一个教程的,只是时间过的挺久,自己都忘记了,前几天我做的一个单子又用到需要英文栏目名,只好再次的整理一下了,

先看下这个效果应用吧。

首先给数据库中的dede_arctype表中增加一个字段,前面的表前缀是你的站点的名,并不一定是dede_

添加后的效果如上图,具体的添加办法再次就不详述了。其中typenameng就是我增加的字段,名称有点长,当然你也可以改为自己乐意的名称,这个不伤大雅。

再找到dede\templets目录下的catalog_edit.htm

找到:

<tr>

<td class='bline' height="26" style="padding-left:10px"><font color='red'>栏目名称:</font></td>

<td class='bline'><input name="typename" type="text" id="typename" size="30" value="<?php echo $myrow['typename']?>" class="iptxt" /></td>

</tr> 

下面添加:

<tr>

<td class='bline' height="26" style="padding-left:10px">栏目英文名称:</td>

<td class='bline'><input name="typenameng" type="text" id="typenameng" size="30" value="<?php echo $myrow['typenameng']?>" class="iptxt" /></td>

</tr> 

最后我们在打开 dede\catalog_edit.php

找到:

$upquery = "UPDATE `#分隔符@__arctype` SET

issend='$issend',

sortrank='$sortrank',

typename='$typename',

typenameng='$typenameng',

typedir='$typedir',

isdefault='$isdefault',

defaultname='$defaultname',  

增加红色的部分,分隔符3个字自行去掉,至此就添加完成了。

调用方式 :{dede:field name='typenameng'/}

想要在channel 中使用,例如:

{dede:channel type='son' row='10' typeid='1'}

<li><a href='[field:typeurl/]'>[field:typename/][field:typenameng/]</a></li>

{/dede:channel}  

则还要修改一个文件,找到include\taglib\channel.lib.php

第一处:

if($type=='top')

{

$sql = "SELECT id,typename,typenameng,typedir,isdefault,ispart,defaultname,namerule2,moresite,siteurl,sitepath

From `#分隔符@__arctype` WHERE reid=0 And ishidden<>1 order by sortrank asc limit 0, $line "

}

else if($type=='son')

{

if($typeid==0) return ''

$sql = "SELECT id,typename,typenameng,typedir,isdefault,ispart,defaultname,namerule2,moresite,siteurl,sitepath

From `#分隔符@__arctype` WHERE reid='$typeid' And ishidden<>1 order by sortrank asc limit 0, $line "

}

else if($type=='self')

{

if($reid==0) return ''

$sql = "SELECT id,typename,typenameng,typedir,isdefault,ispart,defaultname,namerule2,moresite,siteurl,sitepath

FROM `#分隔符@__arctype` WHERE reid='$reid' And ishidden<>1 order by sortrank asc limit 0, $line "

}

第二处:

//如果用子栏目模式,当没有子栏目时显示同级栏目

if($type=='son' &&$reid!=0 &&$totalRow==0)

{

$sql = "SELECT id,typename,typenameng,typedir,isdefault,ispart,defaultname,namerule2,moresite,siteurl,sitepath

FROM `#分隔符@__arctype` WHERE reid='$reid' And ishidden<>1 order by sortrank asc limit 0, $line "

$dsql->SetQuery($sql)

$dsql->Execute()

}  

增加查询字段就可以在channel中使用了,还有type,channelartlist等标签页是在相应的lib类中添加查询的字段,在此限于篇幅就不错详细的叙述了。

您好,朋友。跟版网团队很高兴为您解答:

你上面的教程是错误的,在织梦默认的表中,根本乜有你说的dede_full_search数据表。

要实现您上面的功能,我觉得你可以通过织梦高级自定义搜索实现,也就是用/plus/advancedsearch.php。实现方法如下:

首先在您的内容模型中建立相关字段

建立完成后点击模型后的【自定义搜索】小图标复制里面的代码到您的网页中即可实现此功能。

希望我的回答能够帮到您。

以普通文章频道中新建字段为例:添加“问题答案”字段名称 "daan"点击核心-频道模型-内容模型管理-普通文章

点击 字段管理-添加新字段

依次填写:

(1)表单提示文字:问题答案

(2)字段名称:daan

(3)字段类型:选择 系统自动生成表单字段

(4)数据类型:多行文本

(5)最大长度:1000

点击确定

回到 字段管理页面 如图所示

点击 基本设置

找到 列表附加字段,填入新建字段 daan ,用英文逗号隔开

点击 确定

新建客户问答栏目-编辑问题、答案

问答列表调用代码:

自定义字段在栏目列表中掉用{dede:list pagesize='3'addfields='daan'}

<li >

<a href="[field:arcurl/]">[[field:title/]]</a>

<p>答案:[field:daan function='cn_substr(@me,270)'/]... </p>

</li>

{/dede:list}自定义字段在首页调用:channelid是内容模型的ID号,文章的ID是 "1"{dede:arclist addfields='daan' row='3' channelid='1'}

<a href="[field:arcurl/]">[[field:title/]]</a>

<p>答案:[field:daan function='cn_substr(@me,30)'/]... </p>

{/dede:arclist}

7

生成 客户问答 栏目 查看效果


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11753461.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-18
下一篇 2023-05-18

发表评论

登录后才能评论

评论列表(0条)

保存