• 设为首页
  • 收藏本站
  • 积分充值
  • VIP赞助
  • 手机版
  • 微博
  • 微信
    微信公众号 添加方式:
    1:搜索微信号(888888
    2:扫描左侧二维码
  • 快捷导航
    福建二哥 门户 查看主题

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

    发布者: 酸菜鱼 | 发布时间: 2025-7-24 16:05| 查看数: 117| 评论数: 0|帖子模式

    不过这个解决方法修改了一些文件,你可以根据自己的要求酌情使用。。我在这里也详细说一下解决思路,以便后来人参考学习。
    PHPCMSV9的相关文章,我们知道只有同模型的文章才可以选择。其他模型的文章是选择不成的,可以通过修改模型字段中的“相关参数”来实现选择不同的 模型的文章,但这种方法其实只是实现了一半,虽然能选择了,但是选择保存后,再进入编辑是不会显示的,基本相当于没有实现嘛。
    说一下我的解决方法。
    以我的项目,举个例子。有两个模型,设计师(模型ID是1),设计案例(模型ID为2). 他们的模型ID很重要,后面要用到的。
    我要在设计师的内容中添加设计案例的内容作为设计师的相关作品。
    首先,在模型管理的设计师模型中,修改相关文章的“相关参数”这里面的值。
    找到这行语句,把
     
    代码如下:

    修改为:

    代码如下:
     
    其实只是把上面的 {MODELID} 换成了目标模型ID(设计案例模型的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>  {pc:get sql="select title,id,url,thumb from v9_design where id=$design_id"}
    {loop $data $r}
    [td][url=http://www.jb51.net/blog/{$r}]
    [img=190,120]http://www.jb51.net/blog/{$r[thumb]}[/img]
    [url=http://zhujllove.blog.163.com/blog/{$r}]{str_cut($r[title],'32')}
    [/td] 
    {/loop}
    {/pc}

    {/loop}
    {/if} 
    来源:互联网
    免责声明:如果侵犯了您的权益,请联系站长(1277306191@qq.com),我们会及时删除侵权内容,谢谢合作!

    最新评论

    浏览过的版块

    QQ Archiver 手机版 小黑屋 福建二哥 ( 闽ICP备2022004717号|闽公网安备35052402000345号 )

    Powered by Discuz! X3.5 © 2001-2023

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