找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1610|回复: 0

[分享] 织梦dedecms联动级别前台调用

[复制链接]
发表于 2018-7-29 14:27:40 | 显示全部楼层 |阅读模式 来自 中国–河南–新乡
织梦dedecms系统首页调用分类信息联动类别(地区,类型等)的方法如下:
需要注意:这个方法只适用于dedecms V5.5,V5.6,V5.7
dede模板系统中默认是没有办法调用枚举名(联动菜单名称)的,而只能调用枚举值,为了方便大家在以后制作模板,今天就给大家带来一个自定义的全局函数,有了这个函数,以后在调用联动菜单的时候就非常方便了。
一、遇到问题描述
我们知道,联动菜单它是保存到了附加表里,我们在arclist标签中,要调用自定义附加表的字段,只能是通过:
{dede:arclist row='5' channelid='内容模型ID' addfields='自定义字段'}
insertext
{/dede:arclist}

这种方法来调用,比如以下这个实例:
  1. {dede:arclist titlelen='60' row='8' channelid='1' addfields='nativeplace'}
  2. [field:nativeplace/][field:title /]
  3. {/dede:arclist}
复制代码

这个的意思是调用普通文章8条,并调用附加表中的nativeplace字段(注意:该字段是联动类别),但是调用的结果就是枚举值,是数字,不是地区。
二、解决方法
1)函数编写
打开 /include/extend.func.php 文件(这个文件为自定义函数接口文件,若不存在,请自行创建),在最后一行的?>上添加如下代码:
  1. function Getsysenum($fields){
  2. global $dsql;
  3. $row = $dsql->GetOne("select * from dede_sys_enum where evalue = '".$fields."'");
  4. if(!is_array($row)){
  5. return "联动类别不存在";
  6. }
  7. else{
  8. return $row['ename'];
  9. }
  10. }
复制代码

保存关闭即可!
2)函数调用
这个函数的调用非常简单,只需要将“枚举值”传递过来即可,这个缓存组名通常也就是内容模型中的自定义联动菜单字段名:
function Getsysenum(‘枚举值');
3)调用实例
我们来看一下调用的实例代码:
  1. {dede:arclist titlelen='60' row='8' channelid='1' addfields='nativeplace'}
  2. [field:nativeplace function="Getsysenum(@me)"/][field:title /]
  3. {/dede:arclist}
复制代码

其中[field:nativeplace function="Getsysenum(@me)"/] 就是将nativeplace字段进行Getsysenum函数处理。
这样就可以解决这个调用的问题了。

下面是自定义表单调用联动的使用方法:
织梦官方在自定义表单中把联动类型加了注释的,那么我们现在把注释删除就可以使用了,

找到
/dede/templets/diy_field_add.htm


/dede/templets/diy_field_edit.htm

把注释掉的联动选项给恢复。然后在自定义表单里增加字段,填写联动名,,前台就可以用了。

还有一个就是,这样做出来的联动前台和后台都只显示枚举值,,很烦人,我在网上找到方法,如下:

1.在"后台目录"\templets\diy_list.htm找到(大约在41行):

  1. $fields[$field] = "<a href='{$fields[$field]}' target='_blank'><img src='images/channeladd.gif' border='0' /> 其它附件</a>";
  2. }
复制代码

在下面加入:

  1. //联动类型显示修正开始
  2. else if($fielddata[1]=='stepselect')
  3. {
  4. $db->Execute('me',"SELECT * FROM `dede_stepselect` WHERE itemname='{$fielddata[0]}'");
  5. while($arr = $db->GetArray(me))
  6. {
  7. $egroup = $arr['egroup'];
  8. }
  9. $fields[$field] = Getenums("{$fields[$field]}",$egroup);
  10. }
  11. //联动类型显示修正结束
复制代码

2.找到:

{/dede:datalist}

在下面加入:

  1. <?php
  2. function Getenums($evalue=0,$egroup)
  3. {
  4. if( !isset($GLOBALS['em_'.$egroup.'s']) )
  5. {
  6. $cachefile = DEDEDATA.'/enums/'.$egroup.'.php';
  7. if(!file_exists($cachefile))
  8. {
  9. require_once(DEDEINC.'/enums.func.php');
  10. WriteEnumsCache();
  11. }
  12. if(!file_exists($cachefile))
  13. {
  14. return '';
  15. }
  16. else
  17. {
  18. require_once($cachefile);
  19. }
  20. }
  21. if($evalue>=500)
  22. {
  23. if($evalue % 500 == 0)
  24. {
  25. return (isset($GLOBALS['em_'.$egroup.'s'][$evalue]) ? $GLOBALS['em_'.$egroup.'s'][$evalue] : '');
  26. }
  27. else if (preg_match("#([0-9]{1,})\.([0-9]{1,})#", $evalue, $matchs))
  28. {
  29. $esonvalue = $matchs[1];
  30. $etopvalue = $esonvalue - ($esonvalue % 500);
  31. $esecvalue = $evalue;
  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];
  39. }
  40. else
  41. {
  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];
  49. }
  50. }
  51. }
  52. ?>
复制代码

修改完毕。

需要注意的是:添加新字段时候,表单提示文字必须和联动的组类别名一致,比如我要添加一个表单提示文字是“地区”,那么新增类别组的时候 类别名也要填写“地区”

很多朋友都遇到了DEDECMS自定义表单中地区二级联动后,调用联动字段时只显示地区代码如:


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')这一行,也在

  1. 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部分完

  63. 然后打开view_diyform.htm
  64. 找到<table class='listtable' cellspacing="1">一行
  65. 把下一行还是的到</table>之间的

  66. <?php
  67. echo '<tbody>';
  68. echo '<tr><td bgcolor="#eeeeee" width="20%">id</td><td bgcolor="#eeeeee">'.$row['id'].'</td></tr>';
  69. $allowhtml = array('htmltext');
  70. foreach($fieldlist as $field=>$fielddata)
  71. {
  72. if($row[$field]=='') continue;
  73. if($fielddata[1]=='img')
  74. {
  75.    $row[$field] = "<a href='{$row[$field]}' target='_blank'><img src='{$row[$field]}'/></a>\r\n";
  76. }
  77. else if($fielddata[1]=='addon')
  78. {
  79.    $row[$field] = "<a href='{$row[$field]}' target='_blank'><img src='img/addon.gif' border='0' /> 相关附件</a>";
  80. }
  81. else
  82. {
  83.   if(!in_array($fielddata[1], $allowhtml))
  84.   {
  85.    $row[$field] = htmlspecialchars($row[$field]);
  86.   }
  87. }
  88. echo '<tr><td bgcolor="#ffffff">'.$fielddata[0].'</td><td bgcolor="#ffffff">'.$row[$field].'</td></tr>';
  89. }
  90. echo '</tbody>';
  91. ?>

  92. (也就是将那部分php代码)都删除掉,然后将下面的代码加进去。
  93. <tbody>
  94. <tr><td bgcolor="#eeeeee" width="20%">id</td><td bgcolor="#eeeeee"><?php echo $row['id']; ?></td></tr>
  95. <tr><td bgcolor="#eeeeee" width="20%">生日</td><td bgcolor="#eeeeee"><?php echo $row['shengri']; ?></td></tr>
  96. <tr>
  97.             <td>目前所在地:</td>
  98.             <td> 省份:
  99.               <?php
  100.    $places = GetEnumsTypes($row['nativeplace']);
  101.    echo ( isset($em_nativeplaces[$places['top']]) ?  $em_nativeplaces[$places['top']] : '');
  102.     ?>
  103.                 城市:
  104.               <?php
  105.     echo ( isset($em_nativeplaces[$places['son']]) ?  $em_nativeplaces[$places['son']] : '');
  106.     ?></td>
  107.           </tr>
  108. </tbody>
复制代码


效果请看

list_diyform.htm的改法类似。自己参照更改。
这里要说的是有人会问,替换完了就是地区一项了怎么办?
你自定义表单里的其他项参照这个一行复制就行了
  1. <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-30 14:07 , Processed in 0.035722 second(s), 8 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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