解決{dede:arclist keyword='動態(tài)獲取關鍵詞'}

字號:


    最近在做一個站,想做一個功能,就是有一個div塊里顯示的是與當前文章關鍵詞相同的文章的標題。開始的時候是這樣寫的
    {dede:arclist keyword='{dede:field name='keyword'}'}結果肯定是不可以的。。。。在網(wǎng)上找也沒找到。于是就自己讀代碼,自己寫了個簡單處理的。
    在arclist.lib.php 第149行
    代碼如下:
    //關鍵字條件
    if($keyword!='')
    把{}中間的內容改成
    {
    $rowGetKeyword = $dsql->GetOne("select keywords From `dede_archives` where id='$arcid'");
    $keyword=$rowGetKeyword['keywords'];
    $keyword = str_replace(',', '|', $keyword);
    $orwheres[] = " CONCAT(arc.title,arc.keywords) REGEXP '$keyword' ";
    }
    這樣直接調用{dede:arclist keyword='這里隨便寫只要是不為空就可以'} 這樣這里的keyword就是動態(tài)獲取的了。不然只能是固定的。
    就在剛剛我發(fā)帖之前看到dede5.6里有個標簽
    {dede:likeart titlelen='' row=''}
    {/dede:likeart}
    這個標簽還沒測試,不過應該就是這個功能。如果不是,大家就一用我上面的方法。測試過了,可以用。
    DEDECMS相關文章以關鍵字相關的修改方法
    DEDE的相關文章完全不相關,有朋友在DEDE官方放出根據(jù)TAG顯示相關文章,也是很不錯,可惜我在根據(jù)那邊文章改DEDE代碼后老是不行,可能是能力有限,當然也有可能是代碼有問題
    現(xiàn)在終于出了解決辦法:
    1 在 inc_functions.php 最后?>前 加上
    代碼如下:
    //查詢指定欄目里包含相應關鍵字的文章,并列出
    //參數(shù)說明:$showImg 是否顯示縮略圖,0表示不顯示,1表示顯示
    // $titleLen 標題長度,0表示無限
    // $rowCount 輸出行數(shù),0表示無限
    // $typeid 欄目ID,0表示所有欄目
    // $keyWord 關鍵字,字符串
    function ShowKeyWordArc($showImg,$titleLen,$rowCount,$typeid,$keyWord){
    $dsql = new DedeSql(false);
    $sql = TypeGetSunID($typeid,$dsql); </p> <p>//關鍵字分詞技術
    $ks = explode(" ",$keyWord);
    foreach($ks as $k){
    $k = trim($k);
    if ($k!="") {
    $kwsqlarr[] = " (xkzzz_archives.title like '%$k%')";
    //$kwsqlarr[] = " (xkzzz_archives.keywords like '%$k%') "; //如果需要相關到其它文章的關鍵字,解除此行注釋
    }
    }
    $where = implode(' OR ',$kwsqlarr); </p> <p>$sql="Select tp.namerule,tp.typedir,xkzzz_full_search.aid,xkzzz_full_search.url,xkzzz_archives.* From xkzzz_full_search left join xkzzz_archives on xkzzz_full_search.aid=xkzzz_archives.ID left join xkzzz_arctype tp on xkzzz_archives.typeid=tp.ID where {$sql} and ((xkzzz_archives.title like '%".$keyWord."%') or $where) order by xkzzz_full_search.aid 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."<LI><a href='".$url."' target=_blank>";
    if ($titleLen!=0) $ss=$ss.cn_substr($row->title,$titleLen);
    else $ss=$ss.$row->title;
    $ss=$ss."</A></LI>";
    }else{
    $ss=$ss."<LI><span class='sjdqimggl'><a href='".$url."' target=_blank>"; </p> <p>if ($row->litpic!="") $ss=$ss."<img src='".$row->litpic."' alt='".$row->title."' />";
    else $ss=$ss."<img src='/images/titl.gif'/>";
    $ss=$ss."</a></span><span class='sjdqtxttl'><a href='".$url."' target=_blank>";
    if ($titleLen!=0) $ss=$ss.cn_substr($row->title,$titleLen);
    else $ss=$ss.$row->title;
    $ss=$ss."</A></span></LI>";
    }
    $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”)’/}
    申明:這個函數(shù)不是我寫的
    根據(jù)關鍵字來相關文章,就用戶體驗以及SEO來說都是非常好的
    但是唯一不好的地方就是生成靜態(tài)的時候會慢很多,哈哈,服務器又要辛苦了