帝国CMS跨表调用相关信息标签 跨多表调用 有利于SEO

ECMSPLUS | 2021-03-09 |

摘要:帝国CMS 帝国cms跨多表调用相关信息插件 调用相关信息插件 跨多表...

帝国cms默认调用相关信息的标签为[otherlink]1,”,10,32,0,0,0[/otherlink],系统设置里面也可以选择调用相关的条件。但有个缺陷是不能跨表调用,而且如果调用信息没有就显示空白,不利于优化。eLbECMSPLUS

eLbECMSPLUS

这个是本站的跨多表调用相关信息的效果,可以看到调用了新闻表的同时,也调用模板数据表的内容。eLbECMSPLUS

插件使用方法

以下代码复制粘贴进系统/e/class/userfun.php文件中eLbECMSPLUS

//跨表调用相关链接
//返回相关链接操作类型
function u_OtherLinkQuery($classid,$line,$enews,$doing){
    global $empire,$public_r,$class_r,$class_zr,$navinfor,$dbtbpre,$eyh_r,$etable_r,$class_tr;
    if($enews==1)//按表
    {
        if(strstr($classid,','))//多表
        {
            $tbr=explode(',',$classid);
            $duo=1;
        }
        else
        {
            $tbname=$classid;
            $duo=0;
        }
 
    }
    elseif($enews==2)//按栏目
    {
        if($classid=='selfinfo')//当前栏目
        {
            $classid=$navinfor['classid'];
        }
        $tbname=$class_r[$classid]['tbname'];
        if($class_r[$classid][islast])
        {
            $and="classid='$classid'";
        }
        else
        {
            $and=ReturnClass($class_r[$classid][sonclass]);
        }
 
    }
    elseif($enews==3)//按标题分类
    {
        $tbname=$class_tr[$classid]['tbname'];
        $and="ttid='$classid'";
    }
    else//默认
    {
        $tbname=$class_r[$navinfor[classid]]['tbname'];
    }
    //关键字
    $keys='';
    if(!empty($enews))
    {
        $repadd='';
        $keyr=explode(',',$navinfor['keyboard']);
        $count=count($keyr);
        for($i=0;$i<$count;$i++)
        {
            if($i==0)
            {
                $or='';
            }
            else
            {
                $or=' or ';
            }
            $repadd.=$or."[!--f--!] like '%".$keyr[$i]."%'";
        }
        //搜索范围
        if($public_r['newslink']==1)
        {
            $keys='('.str_replace('[!--f--!]','keyboard',$repadd).')';
        }
        elseif($public_r['newslink']==2)
        {
            $keys='('.str_replace('[!--f--!]','keyboard',$repadd).' or '.str_replace('[!--f--!]','title',$repadd).')';
        }
        else
        {
            $keys='('.str_replace('[!--f--!]','title',$repadd).')';
        }
    }
    else
    {
        $keys='id in ('.$navinfor['keyid'].')';
    }
    //当前信息
    if($tbname==$class_r[$navinfor[classid]][tbname])
    {
        $and.=empty($and)?"id<>'$navinfor[id]'":" and id<>'$navinfor[id]'";
    }
    //图片信息
    if($doing)
    {
        $and.=empty($and)?"ispic=1":" and ispic=1";
    }
    if($and)
    {
        $and.=' and ';
    }
    if(empty($line))
    {
        $line=$class_r[$navinfor[classid]]['link_num'];
    }
    //优化
    $yhvar='otherlink';
    $yhid=$etable_r[$tbname][yhid];
    $yhadd='';
    if($yhid)
    {
        $yhadd=ReturnYhSql($yhid,$yhvar,1);
    }
    if($duo==0)
    {
        $query="select * from {$dbtbpre}ecms_".$tbname." where ".$yhadd.$and.$keys." order by newstime desc limit $line";
    }
    else
    {
        $nowtb=$class_r[$navinfor['classid']]['tbname'];
        $nowid=$navinfor['id'];
        $query='';
        foreach($tbr as $n => $tbname){
            $t=$n+1;
            if($tbname==$nowtb){
                $q.$n="select title,titleurl,newstime,classid,titlepic from ".$dbtbpre."ecms_".$tbname." where ".$yhadd.$and.$keys." and (id>$nowid or id<$nowid)  order by newstime desc limit ".$line;
            }else{
                $q.$n="select title,titleurl,newstime,classid,titlepic from ".$dbtbpre."ecms_".$tbname." where ".$yhadd.$and.$keys."  order by newstime desc limit ".$line;
            }
            $query.='select * from ('.$q.$n.') t'.$t.' union all ';
        }
        $query=substr($query,0,-10).' order by newstime desc limit '.$line;
 
    }
    $sql=$empire->query1($query);
    if(!$sql)
    {
        echo"SQL Error: ".ReRepSqlTbpre($query);
    }
    return $sql;
}
 
//相关链接标签
function u_GetOtherLinkInfo($tempid,$classid='',$line=0,$strlen=60,$have_class=0,$enews=0,$doing=0){
    global $empire,$navinfor,$public_r;
    if(empty($navinfor['keyboard'])||(empty($enews)&&!$navinfor['keyid']))
    {
        return '';
    }
    $sql=u_OtherLinkQuery($classid,$line,$enews,$doing);
    if(!$sql)
    {return "";}
    //取得模板
    $tr=sys_ReturnBqTemp($tempid);
    if(empty($tr['tempid']))
    {return "";}
    $listtemp=str_replace('[!--news.url--]',$public_r[newsurl],$tr[temptext]);
    $subnews=$tr[subnews];
    $listvar=str_replace('[!--news.url--]',$public_r[newsurl],$tr[listvar]);
    $rownum=$tr[rownum];
    $formatdate=$tr[showdate];
    $docode=$tr[docode];
    //替换变量
    $listtemp=ReplaceEcmsinfoClassname($listtemp,$enews,$classid);
    if(empty($rownum))
    {$rownum=1;}
    //字段
    $ret_r=ReturnReplaceListF($tr[modid]);
    //列表
    $list_exp="[!--empirenews.listtemp--]";
    $list_r=explode($list_exp,$listtemp);
    $listtext=$list_r[1];
    $no=1;
    $changerow=1;
    while($r=$empire->fetch($sql))
    {
        $r[oldtitle]=$r[title];
        //替换列表变量
        $repvar=ReplaceListVars($no,$listvar,$subnews,$strlen,$formatdate,$url,$have_class,$r,$ret_r,$docode);
        $listtext=str_replace("<!--list.var".$changerow."-->",$repvar,$listtext);
        $changerow+=1;
        //超过行数
        if($changerow>$rownum)
        {
            $changerow=1;
            $string.=$listtext;
            $listtext=$list_r[1];
        }
        $no++;
    }
    //多余数据
    if($changerow<=$rownum&&$listtext<>$list_r[1])
    {
        $string.=$listtext;
    }
    $string=$list_r[0].$string.$list_r[2];
    echo $string;
}

后台-模板-标签-导入附件中的mylink.bq文件eLbECMSPLUS

前台调用方法

 eLbECMSPLUS

[mylink]标签模板ID,操作对象,调用条数,标题截取字数,是否显示栏目名,操作类型,只显示标题图片的信息[/mylink]
eLbECMSPLUS
标签模板ID:查看标签模板ID点这里

 eLbECMSPLUS

操作对象:对应操作类型的表/栏目/专题。空则为默认。eLbECMSPLUS

操作类型:0为默认;1为按表(多个表格式:’news,photo’);2为按栏目;3为按标题分类eLbECMSPLUS

是否显示栏目名:0为不显示;1为显示eLbECMSPLUS

只显示标题图片的信息:0为不限;1为只显示标题图片的信息eLbECMSPLUS

调用实例

 eLbECMSPLUS

[mylink]2,’news,download,photo,flash,movie,shop,article,info’,10,32,0,1,0[/mylink]
eLbECMSPLUS
标签模板id——2

 eLbECMSPLUS

调用的跨表——news,download,photo,flash,movie,shop,article,infoeLbECMSPLUS

调用条数——10eLbECMSPLUS

截取标题——32eLbECMSPLUS

不显示栏目名——0eLbECMSPLUS

按数据表调用——1eLbECMSPLUS

不限图片属性——0eLbECMSPLUS

免责/版权声明:

本篇文章给大家谈谈帝国CMS跨表调用相关信息标签 跨多表调用 有利于SEO以及帝国CMS对应的知识,感谢你花时间阅读本站内容,希望对各位有所帮助,你也可以查看更多关于帝国CMS的信息。

1、所有来源标注为 ECMSPLUS/zwcms.com的内容版权均为本站所有,若您需要引用、转载,只需要注明来源及原文链接即可,如涉及大面积转载,请来信告知,获取授权。

2、本站所提供的文章资讯、软件资源、素材源码等内容均为作者提供、网友推荐、互联网整理而来(部分报媒/平媒内容转载自网络合作媒体),仅供学习参考,如有侵犯您的版权,请联系我们,本站将在三个工作日内改正。

3、若您的网站或机构从本站获取的一切资源进行商业使用,除来源为本站的资料需与本站协商外,其他资源请自行联系版权所有人。

4、 ECMSPLUS/zwcms.com不保证资源的准确性、安全性和完整性,请您在阅读、下载及使用过程中自行确认,本站亦不承担上述资源对您或您的网站造成的任何形式的损失或伤害

5、未经 ECMSPLUS/zwcms.com允许,不得盗链、盗用本站资源;不得复制或仿造本网站,不得在非 ECMSPLUS/zwcms.com所属的服务器上建立镜像, ECMSPLUS/zwcms.com对其自行开发的或和他人共同开发的所有内容、技术手段和服务拥有全部知识产权,任何人不得侵害或破坏,也不得擅自使用。

6、互联网的本质是自由与分享,我们真诚的希望,每一份有价值的正能量能够在互联网中自由传播,能够为每一个网站提供动力。

标签:
精品源码
  • 二维码种子溯源系统,一物一码防伪验证查询(单用户版) 支持定制开发

    惊爆价¥1500.00

    立即购买
    二维码种子溯源系统,一物一码防伪验证查询(单用户版) 支持定制开发
  • 帝国cms7.5精仿企业信息综合门户《莞商网》(原创)

    惊爆价¥1500.00

    立即购买
    帝国cms7.5精仿企业信息综合门户《莞商网》(原创)
  • 厂房网,厂房出租,厂房出售,仓库出租,园区招商商铺厂房网整站源码

    惊爆价¥1999.00

    立即购买
    厂房网,厂房出租,厂房出售,仓库出租,园区招商商铺厂房网整站源码
看点推荐
精选文章

站长交流群

互联网站长技术交流群
共同学习,共同进步,共同成长!

QQ交流群

推荐文章

EmpireCMS(帝国CMS) 最新版(v7.5)已知漏洞汇总

帝国第三方登陆:微信内部登陆+扫码登陆2.0安装说明与使用方法

帝国cms百度Webupload批量上传组件,支持前台投稿

帝国cms通过用灵动标签的SQL语句查询来调用栏目导航

帝国cms图片集字段morepic分割,自定义图片集显示

帝国cms 技巧整理笔记,持续更新中

帝国cms 技巧整理笔记:常用变量,COOKIE获取和系统模板

最新文章

热门标签

关注我们

微信扫一扫,关注更多精彩

  • 公众号
    全面掌握源码一手资讯

  • 服务号
    精彩活动,推送提醒

垂询热线:18680688182

商务合作:0769-8700 9090
文章投稿: