這些總結,能在開發中快速理解與定位問題所在,希望能幫助.
1.截取調用標題長度
{str_cut($r[title],36,'')}
2.格式化時間
調用格式化時間 2011-05-06 11:22:33:{date('Y-m-d H:i:s',$r[inputtime])}
3.多欄目調用&多推薦位調用
調用需求:文章范圍為59 60 61三個欄目,并且推送到了27 和28兩個推薦位,從第三條開始,連續調用7篇文章,代碼如下:
- {pc:get sql="SELECT * FROM v9_news WHERE id IN (SELECT id FROM v9_position_data WHERE posid in(27,28) and catid in(59,60,61)) order by listorder DESC" cache="3600" start="3" num="7" return="data" }
- {loop $data $n $r}
- ·{str_cut($r[title],22,'')}
- {/loop}
- {/pc}
4.顯示欄目名稱,只是名稱,不帶鏈接:{$catname}
顯示欄目名稱和鏈接,可以點擊:{$CATEGORYS[$r['catid']]['catname']}
5.獲取父欄目id/獲取父欄目名稱
{$CATEGORY[$catid][parentid]}
父欄目名稱:{$CATEGORYS[$CAT[parentid]][catname]}
如,獲取欄目id為1123的欄目名稱:{$CATEGORYS['1123'][catname]}
6.外部數據源調用
dedecmsdb 在后臺數據源處添加:
- {pc:get sql="SELECT * FROM cq_member where mtype='企業' " cache="3600" dbsource="dedecmsdb" num="7" return="data"}
- {loop $data $r}
- {str_cut($r[uname],28,'')}
- {/loop}
- {/pc}
7.調用子欄目,在欄目首頁模板需要用到,代碼如下:
- {pc:content action="category" catid="$catid" num="25" siteid="$siteid" order="listorder ASC"}
- {loop $data $r}
- {$r[catname]} |
- {/loop}
- {/pc}
8.顯示指定id的欄目名稱,例子這里catid=22,代碼如下:
{$CATEGORYS[22]['catname']}
9.在文章面前顯示文章類別,代碼如下:
- {pc:content action="lists" catid="79" order="listorder DESC" num="14" }
- {loop $data $n $r}
- {if $TYPE[$r[typeid]][name]}[ {$TYPE[$r[typeid]][name]}] {/if}{str_cut($r[title],33,'')}
- --Vevb.com
- {/loop}
- {/pc}
10.指定變量循環增長,幻燈片經常用到,代碼如下:
- {pc:content action="lists" catid="66" order="listorder DESC" thumb="1" num="5" }
- {php $num = 0}
- {loop $data $r}
- linkarr[{$num}] = "{$r[url]}";
- picarr[{$num}] = "{$r[thumb]}";
- textarr[{$num}] = "{str_cut($r[title],36,'')}";
- {php $num++}
- {/loop}
- {/pc}
11.文章調用使用limit:
{pc:content action="position" posid="36" num="1" order="listorder DESC limit 1,1--" }
其他都是跟以前一樣使用,代碼如下:
- {pc:content action="position" posid="31" order="listorder DESC" limit='1,8--'}
- {loop $data $r}
- {str_cut($r[title],36,'')}
- {/loop}
- {/pc}
12.文章從指定位置開始調用,起始位置為5,調用3條,相當于limit功能,代碼如下:
- {pc:content action="position" posid="27" order="listorder DESC" num="3" start="5"}
- {loop $data $r}
- {str_cut($r[description],115)}...
- {/loop}
- {/pc}
13.文章列表頁調用關鍵字,或者首頁調用關鍵字.
注意:explode(',',$r[keywords]);是將文章關鍵詞通過英文逗號分離,也就是說每一篇文章都要以逗號間隔關鍵字,否則調用出來會 是全部作為一個關鍵字,如果是空格間隔關鍵字,將explode(',',$r[keywords]);改成explode(' ',$r[keywords]);,代碼如下:
- {pc:content action="lists" catid="$catid" num="10" order="id DESC" page="$page"}
- {loop $data $r}
- {$r[title]}
- {php $keywords = explode(',',$r[keywords]);}
- 文章標簽:
- {loop $keywords $keyword}
- {$keyword}
- {/loop}
- {/loop}
- {/pc}
14.每當列表幾行的時候出現一次某些符號,比如首頁里面的文章推薦,一行顯示兩條,在這兩條中間想加一條豎線 | 就用到這個代碼了,數量大的話就容易出錯,因為模運算嘛~~呵呵 不過一般也就4個標題以下,代碼如下:
- {pc:content action="position" posid="8" order="listorder DESC" num="2"}
- {loop $data $r}
- {str_cut($r[title],26,'')}{if $n%2==1} |{/if}
- {/loop}
- {/pc}
15.v9 列表頁完美支持自定義段調用,代碼如下:
- {pc:content action="lists" catid="$catid" num="25" order="id DESC" page="$_GET['page']" moreinfo="1"}
- {loop $data $r}
- [{$r['字段名']}]> {$r[title]}
- {/loop}
- {$pages}
- {/pc}
16.當前欄目調用父級及以下欄目信息方法,其他代碼,該咋地還是要咋地,這是要素,代碼如下:
- {php $arrchildid = $CATEGORYS[$CAT[parentid]][arrchildid]}
- {pc:get sql="SELECT * FROM v9_news where catid in($arrchildid) cache="3600" page="$page" num="12" return="data"}
17.V9表單功能,提交之后如何返回當前頁面,而不是默認的首頁文件地址,找到 phpcms/modules/formguide/index.php文件第73行:
showmessage(L('thanks'), APP_PATH);
修改成如下代碼即可實現自動返回前一頁:
showmessage(L('thanks'), HTTP_REFERER);
18.v9 首頁或分頁自定義字段調用,和15差不多,第一普通列表或欄目調用自定義字段,在{pc:content action="lists" 后加上副表moreinfo=1,等于1時顯示,0時不顯示.
例子,代碼如下:
- {pc:content action="lists" moreinfo=1 catid="2" order="id DESC" num="4"}
- {loop $data $key $val}
- {$val['title']}
- 價格:{str_cut($v['自定義段'],100)} //100 是字數
- {/loop}
- {/pc}
第二種推薦位調用自定義字段,在模型里加好自定義字段后,必須把“在推薦位標簽中調用”點擊“是“然后用同一樣的方法去調節數據就OK了,記住,如果你加了文章,必須去更新文章才會顯示,自定義段在推薦中只顯示你選擇后,選擇前加的加文章不顯示,更新一下文章就顯示了,例子,代碼如下:
- {pc:content action="position" posid="推薦位id" num="30" thumb="1" moreinfo="1" order="listorder DESC"}
- {loop $data $key $val}
- {$val['title']}
- {str_cut($val['title'],20)}
- {/loop}
- {/pc}
20.編輯器上傳圖片自動使用標題作為alt參數.
一:修改 statics/js/ckeditor/plugins/image/dialogs/image.js,找到:
accessKey:'T','default':''
替換成:accessKey:'T','default':$('#title').val()
二:清除瀏覽器緩存
21.增加文章的隨機點擊數.
找到100行的$views = $r['views'] +1
修改為:
$rand_nums=rand(79,186);
$views = $r['views'] + $rand_nums;
表示點擊一次,增加79到186次不等.
22.增加頁面的彈出框中的提示語,在/phpcms/languages/zh-cn/下,分別對應的不同模塊的系統提示語,如 member.lang.php 是會員模塊的提示語,而調用會話框顯示提示語的系統函數為:
- showmessage(L('please_login', '', 'member'), 'index.php?m=member&c=index&a=login&forward='.$forward);
- //Vevb.com
- function L($language = 'no_language',$pars = array(), $modules = '') {
- }
tips:某些版本出錯民間解決方法.
1.縮略圖以及圖集無法上傳
/phpcms/libs/classes/attachment.class.php
請把24行的(也有可能是23行)
$this->upload_func = 'copy';
改成:
$this->upload_func = 'move_uploaded_file';
22、PHPCMS V9的get標簽調用
1、調用本系統單條數據,示例,調用ID為1的信息,標題長度不超過25個漢字,顯示更新日期:
{get sql="select * from phpcms_content where contentid=1" /}
標題:{str_cut($r[title], 50)} URL:{$r[url]} 更新日期:{date('Y-m-d', $r[updatetime])}
2、調用本系統多條數據,示例,調用欄目ID為1通過審核的10條信息,標題長度不超過25個漢字,顯示更新日期:
- {get sql="select * from phpcms_content where catid=1 and status=99 order by updatetime desc" rows="10"}
- 標題:{str_cut($r[title], 50)} URL:{$r[url]} 更新日期:{date('Y-m-d', $r[updatetime])}
- {/get}
3、帶分頁,示例,調用欄目ID為1通過審核的10條信息,標題長度不超過25個漢字,顯示更新日期,帶分頁:
- {get sql="select * from phpcms_content where catid=1 and status=99 order by updatetime desc" rows="10" page="$page"}
- 標題:{str_cut($r[title], 50)} URL:{$r[url]} 更新日期:{date('Y-m-d', $r[updatetime])}
- {/get}
- 分頁:{$pages}
4、自定義返回變量,示例,調用欄目ID為1通過審核的10條信息,標題長度不超過25個漢字,顯示更新日期,返回變量為 $v:
- {get sql="select * from phpcms_content where catid=1 and status=99 order by updatetime desc" rows="10" return="v"}
- 標題:{str_cut($v[title], 50)} URL:{$v[url]} 更新日期:{date('Y-m-d', $v[updatetime])}
- {/get}
5、調用同一帳號下的其他數據庫,示例,調用數據庫為bbs,分類ID為1的10個最新主題,主題長度不超過25個漢字,顯示更新日期:
- {get dbname="bbs" sql="select * from cdb_threads where fid=1 order by dateline desc" rows="10"}
- 主題:{str_cut($r[subject], 50)} URL:http://bbs.phpcms.cn/viewthread.php?tid={$r[tid]} 更新日期:{date('Y-m-d', $r[dateline])}
- {/get}
6、調用外部數據,示例,調用數據源為bbs,分類ID為1的10個最新主題,主題長度不超過25個漢字,顯示更新日期:
- {get dbsource="bbs" sql="select * from cdb_threads where fid=1 order by dateline desc" rows="10"}
- 主題:{str_cut($r[subject], 50)} URL:http://bbs.phpcms.cn/viewthread.php?tid={$r[tid]} 更新日期:{date('Y-m-d', $r[dateline])}
- {/get}
不知道有沒有朋友在使用中遇到這幾種方法不能滿足需求的時候呢?
例如:取出評論數最多的第3條到第10條記錄,有人說我是多此一舉,一般取最多評論沒理由不取第一和第二條,因為PHPCMS的縮略圖對4:3這樣 的尺寸比較好,對長條形,如3:4,的圖片縮略效果不好,為了自己手動更新評論最多的第一和第二條記錄,故此不想自動更新讀取前兩條.
{$r[comments]}人參與評論·{str_cut($r[title], 28)}
關鍵點就在 order by B.comments desc LIMIT 3,7,表示從第3條記錄開始,向下讀取7條數據,這個在MYSQL是經常用,我抱著試試看的想法,結果是可以的.
phpcms V9 保留了2008的get標簽的使用方法,它包括了2種方式一種是內部數據,另一種是外部數據,我們先分析下內部數據的使用方法.
1、內部數據的調用:
- {pc:get sql="SELECT * FROM `XX` WHERE fid =$ltid AND digest =2 AND ifupload =1 ORDER BY tid DESC" num="2" cache= "3600" return="data" }
- {loop $data $r}
- 。。。。。
- loop}{/pc}
由此可以看出 get 語句支持num的用法但是不支持 limit 5,5.這樣的用法,實在是很遺憾,num是調用的條數.
2、外部數據的調用
- { pc : get sql = "SELECT * FROM phpcms_member" cache = "3600" page = "$page" dbsource = "discuz" return = "data" }
- { loop $data $key $val }
- { $val [ username ]}< br />
- { /loop}
- </ ul >
- { $pages }
- {/ pc }
一個是數據源,一個是產生的pages翻頁效果.
新聞熱點
疑難解答