首先,如果没有显示联动选项的话,请您先阅读《DedeCms自定义表单中联动类型不可用的解决方法》,下面我们讨论DedeCms自定义表单联动类型只显示枚举值的问题,本文的解决方法适用于DedeCms5.5、5.6,其它版本没有测试。
相对于上面的方法,解决以下问题:
1、有多少个自定义的模板,建立多少个diy_list'.$diyid.'.htm,很不灵活
2、每个自定义表单只能建一个联动类型
UTF-8的懒人可以下载附件:diy_list.rar,直接替换,diy_list.htm文件替换到\dede\templets下。
下面是修改方法:
1.在"后台目录"\templets\diy_list.htm找到(大约在41行):
$fields[$field] = "<a href='{$fields[$field]}' target='_blank'><img src='p_w_picpath/channeladd.gif' border='0' /> 其它附件</a>";
}
在下面加入:
//联动类型显示修正开始
1 | else if ($fielddata[1]== 'stepselect' ) |
3 | $db->Execute( 'me' , "SELECT * FROM `dede_stepselect` WHERE itemname='{$fielddata[0]}'" ); |
4 | while ($arr = $db->GetArray(me)) |
6 | $egroup = $arr[ 'egroup' ]; |
8 | $fields[$field] = Getenums( "{$fields[$field]}" ,$egroup); |
|
//联动类型显示修正结束
2.找到:
{/dede:datalist}
在下面加入:
02 | function Getenums($evalue=0,$egroup) |
04 | if ( !isset($GLOBALS[ 'em_' .$egroup. 's' ]) ) |
06 | $cachefile = DEDEDATA. '/enums/' .$egroup. '.php' ; |
07 | if (!file_exists($cachefile)) |
09 | require_once(DEDEINC. '/enums.func.php' ); |
12 | if (!file_exists($cachefile)) |
18 | require_once($cachefile); |
25 | return (isset($GLOBALS[ 'em_' .$egroup. 's' ][$evalue]) ? $GLOBALS[ 'em_' .$egroup. 's' ][$evalue] : '' ); |
27 | else if (preg_match( "#([0-9]{1,})\.([0-9]{1,})#" , $evalue, $matchs)) |
29 | $esonvalue = $matchs[1]; |
30 | $etopvalue = $esonvalue - ($esonvalue % 500); |
32 | $GLOBALS[ 'em_' .$egroup. 's' ][$etopvalue] = empty($GLOBALS[ 'em_' .$egroup. 's' ][$etopvalue])? '' |
33 | : $GLOBALS[ 'em_' .$egroup. 's' ][$etopvalue]; |
34 | $GLOBALS[ 'em_' .$egroup. 's' ][$esonvalue] = empty($GLOBALS[ 'em_' .$egroup. 's' ][$esonvalue])? '' |
35 | : $GLOBALS[ 'em_' .$egroup. 's' ][$esonvalue]; |
36 | $GLOBALS[ 'em_' .$egroup. 's' ][$esecvalue] = empty($GLOBALS[ 'em_' .$egroup. 's' ][$esecvalue])? '' |
37 | : $GLOBALS[ 'em_' .$egroup. 's' ][$esecvalue]; |
38 | return $GLOBALS[ 'em_' .$egroup. 's' ][$etopvalue]. ' - ' .$GLOBALS[ 'em_' .$egroup. 's' ][$esonvalue]. ' - ' .$GLOBALS[ 'em_' .$egroup. 's' ][$esecvalue]; |
42 | $elimit = $evalue % 500; |
43 | $erevalue = $evalue - $elimit; |
44 | $GLOBALS[ 'em_' .$egroup. 's' ][$erevalue] = empty($GLOBALS[ 'em_' .$egroup. 's' ][$erevalue])? '' |
45 | : $GLOBALS[ 'em_' .$egroup. 's' ][$erevalue]; |
46 | $GLOBALS[ 'em_' .$egroup. 's' ][$evalue] = empty($GLOBALS[ 'em_' .$egroup. 's' ][$evalue])? '' |
47 | : $GLOBALS[ 'em_' .$egroup. 's' ][$evalue]; |
48 | return $GLOBALS[ 'em_' .$egroup. 's' ][$erevalue]. ' - ' .$GLOBALS[ 'em_' .$egroup. 's' ][$evalue]; |
|
修改完毕。
需要注意的是:添加新字段时候,表单提示文字必须和联动的组类别名一致,比如我要添加一个表单提示文字是“课程”,那么新增类别组的时候 类别名也要填写“课程”