phpcms v9后台相关文章调用其它模型信息的方法

发布时间:2019-08-27编辑:脚本学堂
本文介绍了phpcms v9后台添加文章时选择相关文章调用其它模型信息的方法,因为业务需要,模型A中的内容要选择模型B中的内容的作为相关文章,在论坛也搜索过,基本上这个问题没有人解决,这里分享下研究后的解决方法。

这个解决方法修改了一些文件,可以根据自己的要求酌情使用。

PHPcmsV9的相关文章,只有同模型的文章才可以选择。其他模型的文章是选择不成的,可以通过修改模型字段中的“相关参数”来实现选择不同的 模型的文章,但这种方法其实只是实现了一半,虽然能选择了,但是选择保存后,再进入编辑是不会显示的,基本相当于没有实现嘛。

解决方法。

以我的项目,举个例子。有两个模型,设计师(模型ID是1),设计案例(模型ID为2). 他们的模型ID很重要,后面要用到的。
我要在设计师的内容中添加设计案例的内容作为设计师的相关作品。

首先,在模型管理的设计师模型中,修改相关文章的“相关参数”这里面的值。
找到这行语句,把
 

复制代码 代码示例:
<input type='button' value="添加相关" onclick="omnipotent('selectid','?m=content&c=content& a=public_relationlist&modelid={MODELID}','添加相关文章',1)" class="button" style="width:66px;">

修改为:
 

复制代码 代码示例:
<input type='button' value="添加相关" onclick="omnipotent('selectid','?m=content&c=content&a=public_relationlist&modelid=2','添加相关文章',1)" class="button" style="width:66px;">
 

其实只是把上面的 {MODELID} 换成了目标模型ID(设计案例模型的ID)罢了。

这一步已经可以实现了选择不同模型的文章。

接下来解决选择后保存后再进入编辑不会显示的问题。
还是找到型管理的设计师模型中,修改相关文章的“相关参数”这里面的值。

 

复制代码 代码示例:
<input type='button' value="显示已有" onclick="show_relation({MODELID},{ID})" class="button" style="width:66px;">
 

修改为:
 

复制代码 代码示例:
<input type='button' value="显示已有" onclick="show_relation(1,2,{ID})" class="button" style="width:66px;">
 

注意第一行的 onclick="show_relation({MODELID},{ID})"
我把他修改为了 onclick="show_relation(1,2,{ID})" , 这里我有必要解释一下, {MODELID}是调用本文章的所属模型ID
我修改为show_relation(1,2,{ID}),懂的朋友一看就知道,我多了一个参数。为什么多了一个参数呢,上面也说到了,默认只有同模型的文章可以选择,所以这里做了一个目标模型ID。第一个参数是源模型ID,第二个参数是目标模型ID。

这里面修改后保存。
show_relation()这个是JS函数,既然多了一个参数,那也要修改JS文件喽。
找到statics/js/content_addtop.js的153,154行左右.为
 

复制代码 代码示例:
function show_relation....
$.getJSON("?m=content;..........
 

把这两行修改为:
 

复制代码 代码示例:
function show_relation(modelid,target_modelid,id) {
$.getJSON("?m=content&c=content&a=public_getjson_ids&modelid="+modelid+"&target_modelid="+target_modelid+"&id="+id, function(json){
 

JS修改过后,接下来我们修改最后的php文件
找到phpcmsmodulescontentcontent.php 574行左右,也就是public function public_getjson_ids()这行左右。

在$modelid = intval($_GET['modelid']); 行后换行:
$target_modelid = intval($_GET['target_modelid']);
在586行也就是$infos = array();这行后面换行加入:
 

复制代码 代码示例:
$this->db->set_model($target_modelid);
$this->model = getcache('model', 'commons');
$this->db->table_name = $this->db->db_tablepre.$this->model[$target_modelid]['tablename'];
 

其中的“$this->db->table_name = $tablename;” 这一行是被上面第三行替换了。
OK。大功告成。
因为已经破坏了原生的相关文章功能了。如果你以后再使用相关文章的功能时,要记得先到模型的字段中的“相关参数”的值哦。

在前台调用相关文章时,用下列标签:
 

复制代码 代码示例:
if $relation!=''}
{php $rel = explode('|',$relation);}
{loop $rel $design_id} </p> <p> {pc:get sql="select title,id,url,thumb from v9_design where id=$design_id"}
{loop $data $r}
<td class="pr5"><a href="http://www.jb200.com/blog/{$r[url]}" title="{$r[title]}" target="_blank"><img src="http://www.jb200.com/blog/{$r[thumb]}" width="190" height="120" class="imgborder" alt="{$r[title]}" /></a><p class="mt5"><a href="http://zhujllove.blog.163.com/blog/{$r[url]}" title="{$r[title]}" target="_blank">{str_cut($r[title],'32')}</a></p></td>
{/loop}
{/pc}</p> <p>{/loop}
{/if}