收藏本站 依旧织梦网(19dede.com),专注织梦模板设计制作!
当前位置:主页 > 织梦教程 > 常见问题 >

DEDECMS自定义表单中地区联动显示数字的解决办法

时间:2016-09-19 22:04 来源:www.19dede.com 作者:依旧织梦网 阅读:

很多朋友都遇到了DEDECMS自定义表单中地区二级联动后,调用联动字段时只显示地区代码13003其实是贵州省遵义市的系统联动类编号,要让其显示成贵州省遵义市其实也比较容易。

需要修改3个文件:

  • 根目录下plus/diy.php
  • 根目录下templates/plus/view_diyform.htm
  • 根目录下templates/plus/list_diyform.htm(和view_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’;

然后在下面加入两行:

include_once(DEDEDATA.’/enums/nativeplace.php’);
include_once(DEDEINC.”/enums.func.php”);


详细代码如下(修改后)

elseif($action == ‘list’)
{
if(empty($diy->public))
{
 showMsg(‘后台关闭前台浏览’, ‘javascript:;’);
 exit();
}
include_once DEDEINC.’/datalistcp.class.php’;
include_once(DEDEDATA.’/enums/nativeplace.php’);
include_once(DEDEINC.”/enums.func.php”);
if($diy->public == 2)
{
 $query = “select * from `{$diy->table}` order by id desc”;
}
else
{
 $query = “select * from `{$diy->table}` where ifcheck=1 order by id desc”;
}
$datalist = new DataListCP();
$datalist->pageSize = 10;
$datalist->SetParameter(‘action’, ‘list’);
$datalist->SetParameter(‘diyid’, $diyid);
$datalist->SetTemplate(DEDEINC.”/../templets/plus/{$diy->listTemplate}”);
$datalist->SetSource($query);
$fieldlist = $diy->getFieldList();
$datalist->Display();
}
//list部分完

elseif($action == ‘view’)
{
if(empty($diy->public))
{
 showMsg(‘后台关闭前台浏览’ , ‘javascript:;’);
 exit();
}

if(empty($id))
{
 showMsg(‘非法操作!未指定id’, ‘javascript:;’);
 exit();
}
include_once DEDEINC.’/datalistcp.class.php’;
include_once(DEDEDATA.’/enums/nativeplace.php’);
include_once(DEDEINC.”/enums.func.php”);
if($diy->public == 2)
{
 $query = “select * from {$diy->table} where id=’$id’ “;
}
else
{
 $query = “select * from {$diy->table} where id=’$id’ and ifcheck=1″;
}
$row = $dsql->getone($query);
if(!is_array($row))
{
 showmsg(‘你访问的记录不存在或未经审核’, ‘-1′);
 exit();
}

$fieldlist = $diy->getFieldList();

include DEDEROOT.”/templets/plus/{$diy->viewTemplate}”;
}
?>

//view部分完

二,修改view_diyform.htm文件


找到:

<table class=’listtable’ cellspacing=”1″>

将下面的代码删除:

<?php
echo ‘<tbody>’;
echo ‘<tr><td bgcolor=”#eeeeee” width=”20%”>id</td><td bgcolor=”#eeeeee”>’.$row['id'].’</td></tr>’;
$allowhtml = array(‘htmltext’);
foreach($fieldlist as $field=>$fielddata)
{
if($row[$field]==”) continue;
if($fielddata[1]==’img’)
{
 $row[$field] = “<a href=’{$row[$field]}’ target=’_blank’><img src=’{$row[$field]}’/></a>\r\n”;
}
else if($fielddata[1]==’addon’)
{
 $row[$field] = “<a href=’{$row[$field]}’ target=’_blank’><img src=’img/addon.gif’ border=’0′ /> 相关附件</a>”;
}
else
{
 if(!in_array($fielddata[1], $allowhtml))
 {
 $row[$field] = htmlspecialchars($row[$field]);
 }
}
echo ‘<tr><td bgcolor=”#ffffff”>’.$fielddata[0].’</td><td bgcolor=”#ffffff”>’.$row[$field].’</td></tr>’;
}
echo ‘</tbody>’;
?>

然后把下方的代码替换进去:

<tbody>
<tr><td bgcolor=”#eeeeee” width=”20%”>id</td><td bgcolor=”#eeeeee”><?php echo $row['id']; ?></td></tr>
<tr><td bgcolor=”#eeeeee” width=”20%”>生日</td><td bgcolor=”#eeeeee”><?php echo $row['shengri']; ?></td></tr>
 <tr>
 <td>目前所在地:</td>
 <td> 省份:
 <?php
 $places = GetEnumsTypes($row['nativeplace']);
 echo ( isset($em_nativeplaces[$places['top']]) ? $em_nativeplaces[$places['top']] : ”);
 ?>
 &nbsp; 城市:
 <?php
 echo ( isset($em_nativeplaces[$places['son']]) ? $em_nativeplaces[$places['son']] : ”);
 ?></td>
 </tr>
</tbody>

三,修改list_diyform.htm文件


修改方法和修改view_diyform.htm相同。

本文版权归原作者所有,转载请注明原文来源出处,依旧织梦网感谢您的支持!

本文链接:http://www.19dede.com/question/78.html DEDECMS自定义表单中地区联动显示数字的解决办法http://www.19dede.com/question/78.html

广告
相关内容:
发表评论:
特价模板
特价织梦模板本站将持续推出,特价模板不参与其他促销活动!