如何任意調用數據庫中的內容呢?先舉個例子:大家都知道DEDECMS5.6後台有個頻道模型裡面有添加單頁文檔的功能,但如何在首頁調用單頁文檔的內容呢,現在給大家講下如何使用:
1.首頁在後台單頁文檔管理裡添加一個單頁文檔,內容編輯框輸入你要的內容生成。
2.在需要調用單頁文檔的地方加入SQL萬用標簽{dede:sql sql="select body from dede_sgpage where aid=2"}[field:body /]{/dede:sql} 相信熟悉SQL語言的朋友很容易看懂這句含義。意思其實就是選擇數據表dede_sgpage 的body字段輸入,aid=2這裡的2表示你創建單頁文檔ID數字,你使用時做下相應修改即可。
如這句SQL標簽樣例代碼:
{dede:sql sql="select content from dede_arctype where id=2"}
[field:content function=cn_substr(Html2Text(@me),600)/]
{/dede:sql}
根據上面的例子,應該很好理解了,這裡主要說明一下cn_substr表示截取600個字符也就是300個漢字。Html2Text代表把含有HTML的字符過濾掉,只顯示文本。
其實除了上面的例子外,在Dede系統裡面,我可以可以自由使用SQL語句來配合織夢標簽進行更多的個性化調用。他們的基本參照格式為:
{dede:sql sql="select 字段 From 表名稱 where 條件語句"}
[field:字段名/]
{/dede:sql}
由上面這種基本格式,我們就可以基本轉換出一條調用文檔列表的調用標簽了,代碼為:
{dede:sql sql="select * From dede_archives limit 10"}
<li>·<a href="/plus/view.php?aid=[field:id/]">[field:title/]</a></li>
{/dede:sql}
大家看到了上面的文檔鏈接的底層DEDECMS模板地址的是動態的,那麼我們要怎麼樣來進行轉換,讓他鏈接到靜態地址呢,這裡我們只需要對[field:id/]進行一下轉換,轉換後的完整代碼為:
{dede:sql sql="SELECT * FROM dede_archives limit 10"}
<li>·<a href="[field:id runphp='yes'] $id=@me;@me='';
$url=GetOneArchive($id);@me=$url['arcurl'];[/field:id]"
title="[field:title/]" target="_blank">
[field:title function=cn_substr(@me,30,0)/]</a></li>
{/dede:sql}
*