站长之家 - 站长资讯 - 易采站长站

当前位置: > 建站教程 > 源码教程 > CMS 教程 >

phpcms v9后台添加文章时选择相关文章可调用其它模型信息的方法

2018-06-03 14:11 | 来源:易采源码网 | 编辑:admin |

不过这个解决方法修改了一些文件,你可以根据自己的要求酌情使用。。我在这里也详细说一下解决思路,以便后来人参考学习。

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文件。

找到\phpcms\modules\content\content.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.jb51.net/blog/{$r[url]}" title="{$r[title]}" target="_blank"><img src="http://www.jb51.net/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}

  • phpcms V9实现qq登陆oauth2.0的方法
  • phpcms v9栏目列表从N条开始选择性调用数据的方法
  • PHPCMS开启全文搜索(sphinx)后搜索无效的解决方法
  • PHPCMS取消搜索时的分词功能的方法
  • phpcms教程之增加统计代码可以统计每天发表文章数量
  • phpcms 投稿问题之游客投稿(不用登录)
  • phpcms v9将栏目描述的多行文本修改为编辑器
  • phpcms根据栏目放置加载不同广告方法分享
  • phpcms v9出现Can not connect to MySQL server错误的原因和解决方法
  • PHPCMS通过getJSON调用的地址回调函数一直无法执行
  • 网友评论

    关于我们 - 联系我们 - 广告服务 - 版权声明 - 人才招聘 - 友情链接 - 网站地图 - 帮助 - -

    CopyRight © 2010-2016 源码下载 easck.com , All Rights Reserved

    蒙公网安备 15052402000103号

    蒙ICP备14002389-1号