首页 > 问答 > 写dedecms模版的时候遇到了一个关键性问题。。。求DEDE大神来祝

写dedecms模版的时候遇到了一个关键性问题。。。求DEDE大神来祝

[导读]:准备仿一个影视站,写模版的时候遇到了一个关键性问题。。。求DEDE大神来祝我一臂之力! typeid里面的值是不能通过嵌套标签fenjiid来获得,这个要是不用sql的话,需要修改底层...

准备仿一个影视站,写模版的时候遇到了一个关键性问题。。。求DEDE大神来祝我一臂之力!



typeid里面的值是不能通过嵌套标签fenjiid来获得,这个要是不用sql的话,需要修改底层程序,修改arclist标签,增加一个变量开关,如果增加这个变量有值,那么就调用当id所在栏目typeid,传给arclist标签,文章最后给你看一个如何实现动态keyword的资料。
解决方案:
1、就是你做模板的时候一个栏目做一个模板,这样的话你写标签的时候,一个栏目指定一个typeid就可以了
2、使用织梦的相关文档标签或者keyword关键词来聚合文章
{dede:likearticle col='2' row='10' titlelen='42'}
  • [field:title/]
  • {/dede:likearticle}
    {dede:arclist keyword='关键词'}
    {/dede:arclist}
    3、使用channelarclist标签显示目录级别的文章列表
    {dede:channelarclist }
    {dede:arclist typeid='[field:typeid]'}
    {/dede:arclist}
    {/dede:channelarclist}
    4、修改底层文件方案:
    {dede:arclist keyword='{dede:field name='keyword'}'}的实现方法
    在 第149行  

      代码如下:

      //关键字条件
    if($keyword!='')
    把{}中间的内容改成
    {
    $rowGetKeyword = $dsql->GetOne("select keywords From dede_archives where id='$arcid'");
    $keyword=$rowGetKeyword['keywords'];
    $keyword = str_replace(',', '|', $keyword);
    $orwheres[] = " CONCAT(,) REGEXP '$keyword' ";
    }

      这样直接调用{dede:arclist keyword='这里随便写只要是不为空就可以'} 这样这里的keyword就是动态获取的了。不然只能是固定的。

    5、相关文章的底层PHP修改方案
    DEDE的相关文章完全不相关,有朋友在DEDE官方放出根据TAG显示相关文章,也是很不错,可惜我在根据那边文章改DEDE代码后老是不行,可能是能力有限,当然也有可能是代码有问题

      现在终于出了解决办法:

      1 在 inc_ 最后?>前 加上

      

      代码如下:

      //查询指定栏目里包含相应关键字的文章,并列出
    //参数说明:$showImg 是否显示缩略图,0表示不显示,1表示显示
    // $titleLen 标题长度,0表示无限
    // $rowCount 输出行数,0表示无限
    // $typeid 栏目ID,0表示所有栏目
    // $keyWord 关键字,字符串
    function ShowKeyWordArc($showImg,$titleLen,$rowCount,$typeid,$keyWord){
    $dsql = new DedeSql(false);
    $sql = TypeGetSunID($typeid,$dsql);

    //关键字分词技术
    $ks = explode(" ",$keyWord);
    foreach($ks as $k){
    $k = trim($k);
    if ($k!="") {
    $kwsqlarr[] = " (xkzzz_ like '%$k%')";
    //$kwsqlarr[] = " (xkzzz_ like '%$k%') "; //如果需要相关到其它文章的关键字,解除此行注释
    }
    }
    $where = implode(' OR ',$kwsqlarr);

    $sql="Select ,,xkzzz_full_,xkzzz_full_,xkzzz_archives.* From xkzzz_full_search left join xkzzz_archives on xkzzz_full_ left join xkzzz_arctype tp on xkzzz_ where {$sql} and ((xkzzz_ like '%".$keyWord."%') or $where) order by xkzzz_full_ desc";
    $dsql->SetQuery($sql);
    $dsql->Execute();
    $ss="";
    $i=0;
    while($row=$dsql->GetObject()){
    $url=GetFileUrl($row->ID,$row->typeid,$row->senddate,$row->title,$row->ismake,$row->arcrank,$row->namerule,$row->typedir,$row->money);
    if ($showImg==0){
    $ss=$ss."

  • ";
    if ($titleLen!=0) $ss=$_substr($row->title,$titleLen);
    else $ss=$ss.$row->title;
    $ss=$ss."
  • ";
    }else{
    $ss=$ss."
  • ";

    if ($row->litpic!="") $ss=$ss."".$row->title."";
    else $ss=$ss."";
    $ss=$ss."

    ";
    if ($titleLen!=0) $ss=$_substr($row->title,$titleLen);
    else $ss=$ss.$row->title;
    $ss=$ss."
  • ";
    }
    $i++;
    if (($rowCount!=0)&&($i>=$rowCount)) return $ss;
    }
    return $ss;
    }

      2 放在文章模板页内

      {dede:field name=’keywords’ function=’ShowKeyWordArc(0,32,10,0,”@me”)’/}
    就表示是取所有栏目内的相关文章(与当前文章的关键字相关),标题长度最大32,最多显示10条,不显示缩略图

      或
    {dede:field name=’keywords’ function=’ShowKeyWordArc(0,32,10,0,”高三 语文”)’/}
    可以找到标题里,含有“高三 语文”,或者含有“高三”或“语文”的文章

      例如,这一段:

      相关文章
    {dede:likeart titlelen=’24′ row=’10′}

      [field:textlink/]< >
    {/dede:likeart}

      就改成:

      相关文章
    {dede:field name=’keywords’ function=’ShowKeyWordArc(0,32,10,0,”@me”)’/}

    想动态实现需要修改底层php程序,想自己使用方便,建议每个栏目做个模板,模板复制下,速度也不慢,当然复制模板的方法仅限于php基础差或者刚学php的朋友,有多年php经验的可以,自己修改底层PHP程序,最近在用yiqiCMS修改内容,发现YIQICMS可扩展性很大,要是有兴趣的朋友可以加我qq5267603一起研究下###

    1、{dede:list} 。。。 {/dede:list} 这是作为栏目页的模板的时候,可以通过这个标签调用改栏目页的的文章作为列表文章。

    2、{dede:arclist}。。。 {/dede:arclist} 这个是当他不是作为该栏目的模板的时候,在其他页面调用改指定栏目的标签。

    作为栏目页的话,用第一个:

    {dede:list}



  • [field:title/]


  • {/dede:list}

    你的是第二种:
    {dede:arclist typeid='栏目id' titlelen='15'}





  • [field:fulltitle/]




  • {/dede:arclist}
    是不是typeid='' 缺少单引号。排除一下, 写法是正确的。

    本文来自投稿,不代表微盟圈立场,如若转载,请注明出处:https://www.vm7.com/a/ask/32079.html