找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1636|回复: 0

[分享] DEDECMS自定义表单中地区联动显示的解决办法!

[复制链接]
发表于 2018-7-29 09:15:21 | 显示全部楼层 |阅读模式 来自 中国–河南–新乡
很多朋友都遇到了DEDECMS自定义表单中地区二级联动后,调用联动字段时只显示地区代码如:
1.webp
13003其实是贵州省遵义市的系统联动类编号,
要让其显示成贵州省遵义市其实也比较容易。
需要动3个文件。
第一个是根目录plus/diy.php。
第二个是上一个php对应的模板文件更目录下templates/plus/view_diyform.htm和list_diyform.htm(两个模板文件改法一样)。
提醒一下注意备份要修改的这几个文件。
现在开始了对于diy.php打开后找到elseif($action == 'list')这一行,再在它的下边找到
include_once DEDEINC.'/datalistcp.class.php';下面加入
include_once(DEDEDATA.'/enums/nativeplace.php');
include_once(DEDEINC."/enums.func.php");
这样两个,
同样找到elseif($action == 'view')这一行,也在
include_once DEDEINC.'/datalistcp.class.php';下加入上边的红色两句
详细代码如下
  1. elseif($action == 'list')
  2. {
  3. if(empty($diy->public))
  4. {
  5.   showMsg('后台关闭前台浏览', 'javascript:;');
  6.   exit();
  7. }
  8. include_once DEDEINC.'/datalistcp.class.php';
  9. include_once(DEDEDATA.'/enums/nativeplace.php');
  10. include_once(DEDEINC."/enums.func.php");
  11. if($diy->public == 2)
  12. {
  13.   $query = "select * from `{$diy->table}` order by id desc";
  14. }
  15. else
  16. {
  17.   $query = "select * from `{$diy->table}` where ifcheck=1 order by id desc";
  18. }
  19. $datalist = new DataListCP();
  20. $datalist->pageSize = 10;
  21. $datalist->SetParameter('action', 'list');
  22. $datalist->SetParameter('diyid', $diyid);
  23. $datalist->SetTemplate(DEDEINC."/../templets/plus/{$diy->listTemplate}");
  24. $datalist->SetSource($query);
  25. $fieldlist = $diy->getFieldList();
  26. $datalist->Display();
  27. }
  28. //list部分完

  29. elseif($action == 'view')
  30. {
  31. if(empty($diy->public))
  32. {
  33.   showMsg('后台关闭前台浏览' , 'javascript:;');
  34.   exit();
  35. }
  36. if(empty($id))
  37. {
  38.   showMsg('非法操作!未指定id', 'javascript:;');
  39.   exit();
  40. }
  41. include_once DEDEINC.'/datalistcp.class.php';
  42. include_once(DEDEDATA.'/enums/nativeplace.php');
  43. include_once(DEDEINC."/enums.func.php");
  44. if($diy->public == 2)
  45. {
  46.   $query = "select * from {$diy->table} where id='$id' ";
  47. }
  48. else
  49. {
  50.   $query = "select * from {$diy->table} where id='$id' and ifcheck=1";
  51. }
  52. $row = $dsql->getone($query);
  53. if(!is_array($row))
  54. {
  55.   showmsg('你访问的记录不存在或未经审核', '-1');
  56.   exit();
  57. }
  58. $fieldlist = $diy->getFieldList();
  59. include DEDEROOT."/templets/plus/{$diy->viewTemplate}";
  60. }
  61. ?>
  62. //view部分完
复制代码

然后打开view_diyform.htm
找到<table class='listtable' cellspacing="1">一行
把下一行还是的到</table>之间的
  1. <?php
  2. echo '<tbody>';
  3. echo '<tr><td bgcolor="#eeeeee" width="20%">id</td><td bgcolor="#eeeeee">'.$row['id'].'</td></tr>';
  4. $allowhtml = array('htmltext');
  5. foreach($fieldlist as $field=>$fielddata)
  6. {
  7. if($row[$field]=='') continue;
  8. if($fielddata[1]=='img')
  9. {
  10.    $row[$field] = "<a href='{$row[$field]}' target='_blank'><img src='{$row[$field]}'/></a>\r\n";
  11. }
  12. else if($fielddata[1]=='addon')
  13. {
  14.    $row[$field] = "<a href='{$row[$field]}' target='_blank'><img src='img/addon.gif' border='0' /> 相关附件</a>";
  15. }
  16. else
  17. {
  18.   if(!in_array($fielddata[1], $allowhtml))
  19.   {
  20.    $row[$field] = htmlspecialchars($row[$field]);
  21.   }
  22. }
  23. echo '<tr><td bgcolor="#ffffff">'.$fielddata[0].'</td><td bgcolor="#ffffff">'.$row[$field].'</td></tr>';
  24. }
  25. echo '</tbody>';
  26. ?>
复制代码

(也就是将那部分php代码)都删除掉,然后将下面的代码加进去。
  1. <tbody>
  2. <tr><td bgcolor="#eeeeee" width="20%">id</td><td bgcolor="#eeeeee"><?php echo $row['id']; ?></td></tr>
  3. <tr><td bgcolor="#eeeeee" width="20%">生日</td><td bgcolor="#eeeeee"><?php echo $row['shengri']; ?></td></tr>
  4.           <tr>
  5.             <td>目前所在地:</td>
  6.             <td> 省份:
  7.               <?php
  8.    $places = GetEnumsTypes($row['nativeplace']);
  9.    echo ( isset($em_nativeplaces[$places['top']]) ?  $em_nativeplaces[$places['top']] : '');
  10.     ?>
  11.               &nbsp; 城市:
  12.               <?php
  13.     echo ( isset($em_nativeplaces[$places['son']]) ?  $em_nativeplaces[$places['son']] : '');
  14.     ?></td>
  15.           </tr>
  16. </tbody>
复制代码

效果请看
1.webp


list_diyform.htm的改法类似。自己参照更改。
这里要说的是有人会问,替换完了就是地区一项了怎么办?
你自定义表单里的其他项参照这个一行复制就行了<tr><td bgcolor="#eeeeee" width="20%">id</td><td bgcolor="#eeeeee"><?php echo $row['id']; ?></td></tr>
其中红色的id可替换成你的其他字段的中文名,蓝色id替换成字段对应的数据库中的字段名(一定是英文或这拼音,这个不用我多说了吧!)。

发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;

如何回报帮助你解决问题的坛友,好办法就是点击帖子下方的评分按钮给对方加【金币】不会扣除自己的积分,做一个热心并受欢迎的人!

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

本版积分规则 需要先绑定手机号

关闭

站长推荐上一条 /1 下一条

QQ|侵权投诉|广告报价|手机版|小黑屋|西部数码代理|飘仙建站论坛 ( 豫ICP备2022021143号-1 )

GMT+8, 2024-11-22 08:07 , Processed in 0.036518 second(s), 6 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表