小編給大家分享一下解決dede:arclist keyword的問題,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
為云和等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計制作服務(wù),及云和網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都做網(wǎng)站、成都網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設(shè)、云和網(wǎng)站設(shè)計,以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!
怎么解決{dede:arclist keyword='動態(tài)獲取關(guān)鍵詞'}?
解決{dede:arclist keyword='動態(tài)獲取關(guān)鍵詞'}
推薦學習:織夢cms
最近修改模版,為了讓相關(guān)文章的相關(guān)度更高,打算優(yōu)化一下,不過會增加生成頁面時間,如果不經(jīng)常更新倒是不錯的
最近在做一個站,想做一個功能,就是有一個div塊里顯示的是與當前文章關(guān)鍵詞相同的文章的標題。開始的時候是這樣寫的
{dede:arclist keyword='{dede:field name='keyword'}'}結(jié)果肯定是不可以的。。。。在網(wǎng)上找也沒找到。于是就自己讀代碼,自己寫了個簡單處理的。
在arclist.lib.php 第149行
代碼如下:
//關(guān)鍵字條件 if($keyword!='')
把{}中間的內(nèi)容改成
{ $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' "; }
這樣直接調(diào)用{dede:arclist keyword='這里隨便寫只要是不為空就可以'} 這樣這里的keyword就是動態(tài)獲取的了。不然只能是固定的。
就在剛剛我發(fā)帖之前看到dede5.6里有個標簽
{dede:likeart titlelen='' row=''} {/dede:likeart}
這個標簽還沒測試,不過應(yīng)該就是這個功能。如果不是,大家就一用我上面的方法。測試過了,可以用。
DEDECMS相關(guān)文章以關(guān)鍵字相關(guān)的修改方法
DEDE的相關(guān)文章完全不相關(guān),有朋友在DEDE官方放出根據(jù)TAG顯示相關(guān)文章,也是很不錯,可惜我在根據(jù)那邊文章改DEDE代碼后老是不行,可能是能力有限,當然也有可能是代碼有問題
現(xiàn)在終于出了解決辦法:
1 在 inc_functions.php 最后?>前 加上
代碼如下:
//查詢指定欄目里包含相應(yīng)關(guān)鍵字的文章,并列出 //參數(shù)說明:$showImg 是否顯示縮略圖,0表示不顯示,1表示顯示 // $titleLen 標題長度,0表示無限 // $rowCount 輸出行數(shù),0表示無限 // $typeid 欄目ID,0表示所有欄目 // $keyWord 關(guān)鍵字,字符串 function ShowKeyWordArc($showImg,$titleLen,$rowCount,$typeid,$keyWord){ $dsql = new DedeSql(false); $sql = TypeGetSunID($typeid,$dsql);//關(guān)鍵字分詞技術(shù) $ks = explode(" ",$keyWord); foreach($ks as $k){ $k = trim($k); if ($k!="") { $kwsqlarr[] = " (xkzzz_archives.title like '%$k%')"; //$kwsqlarr[] = " (xkzzz_archives.keywords like '%$k%') "; //如果需要相關(guān)到其它文章的關(guān)鍵字,解除此行注釋 } } $where = implode(' OR ',$kwsqlarr);
$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."
if ($row->litpic!="") $ss=$ss."litpic."' alt='".$row->title."' />"; else $ss=$ss.""; $ss=$ss."
"; if ($titleLen!=0) $ss=$ss.cn_substr($row->title,$titleLen); else $ss=$ss.$row->title; $ss=$ss."2 放在文章模板頁內(nèi)
{dede:field name=’keywords’ function=’ShowKeyWordArc(0,32,10,0,”@me”)’/}
就表示是取所有欄目內(nèi)的相關(guān)文章(與當前文章的關(guān)鍵字相關(guān)),標題長度最大32,最多顯示10條,不顯示縮略圖
或
{dede:field name=’keywords’ function=’ShowKeyWordArc(0,32,10,0,”高三 語文”)’/} 可以找到標題里,含有“高三 語文”,或者含有“高三”或“語文”的文章
例如,這一段:
相關(guān)文章 {dede:likeart titlelen=’24′ row=’10′} [field:textlink/]< > {/dede:likeart}
就改成:
相關(guān)文章 {dede:field name=’keywords’ function=’ShowKeyWordArc(0,32,10,0,”@me”)’/}
申明:這個函數(shù)不是我寫的
根據(jù)關(guān)鍵字來相關(guān)文章,就用戶體驗以及SEO來說都是非常好的
但是唯一不好的地方就是生成靜態(tài)的時候會慢很多,哈哈,服務(wù)器又要辛苦了
以上是解決dede:arclist keyword的問題的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!