调用phpcms v9模板制作常用代码集合

phpcms模板  时间:2021-03-20  阅读:()

1.截取调用标题长度

{str_cut($r[title],36,'')}

2.格式化时间

调用格式化时间2011-05-0611:22:33

{date('Y-m-d H: i:s',$r[inputtime])}

3.多栏目调用&多推荐位调用

调用需求文章范围为596061三个栏目并且推送到了27和28两个推荐位从第三条开始连续调用7篇文章。

{pc:get sql="SELECT*FROM v9_news WHERE id IN(SELECT id FROMv9_position_data WHERE posid in(27,28)and catid in(59,60,61))order by listorderDESC"cache="3600"sta rt="3"num="7" return="data" }

{loop$data $n$r}

<l i>·<a target="_blank" href='{$r[url]}' title="{$r[title]}"style="color:B lack;">{str_cut($r[title],22,'')}</a></li>

{/loop}

{/pc}

4.显示栏目名称叧是名称丌带链接

{$catname}

显示栏目名称和链接可以点击

<a href="{$CATEGORYS[$r[catid]][url]}">{$CATEGORYS[$r['catid']]['catname']}</A>

5.获取父栏目id/获取父栏目名称

{$CAT EGORY[$catid][pa rentid]}

父栏目名称 {$CAT EGORYS[$CAT[parentid]][catname]}

6.外部数据源调用dedecmsdb在后台数据源处添加

{pc:get sql="SELECT*FROM cq_member where mtype='企业' "cache="3600"dbsource="dedecmsdb"num="7" return="data"}

{loop$data $r}

<a href="/member/index.php?uid={$r[userid]}" title="{$r[uname]}"target="_blank">{str_cut($r[uname],28,'')}</a>

{/loop}

{/pc}

7.调用子栏目在栏目首页模板需要用到

{pc:content action="category"catid="$catid" num="25" siteid="$site id"order="listorder ASC"}

{loop$data $r}

<a href="{$r[url]}">{$r[catname]}</a>|

{/loop}

{/pc}

8.显示指定id的栏目名称例子这里catid=22

{$CATEGORYS[22]['catname']}

9.在文章面前显示文章类别

{pc:content action="lists"catid="79"order="listorder DESC" num="14" }

<?php$TY PE=getcache('type_content','commons');?>

{loop$data $n$r}

<l i>{if$TYPE[$r[typeid]][name]}<spa nstyle="color:#CC6600">[ {$TYPE[$r[typeid]][name]}]</span>{/if}<ahref="{$r['url']}"{t it le_style($r[style])}tit le="{$r['t it le']}"target="_blank">{str_cut($r[title],33,'')}</a></li>

{/loop}

{/pc}

10.指定变量循环增长幻灯片经常用到

{pc:content action="lists"catid="66"order="listorder DESC" thumb="1" num="5"}{php$num=0}

{loop$data $r}l inkarr[{$n um}]="{$r[url]}"icarr[{$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" lim it='1,8--'}{loop$data $r}

<l i><a href="{$r[url]}" title="{$r[title]}"target=_blank>{str_cut($r[title],36,'')}</a></li>

{/loop}

{/pc}

12.文章从指定位置开始调用

起始位置为5 调用3条。相当于lim it功能。

{pc:content action="position"posid="27"order="listorder DESC" num="3"sta rt="5"}

{loop$data $r}

<a href='{$r[url]}'>{str_cut($r[description],115)}. . .</a>

{/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}

<a href="{$r[url]}">{$r[title]}</a>

{php$keywords=explode(',',$r[keywords]);}

<b>文章标签:</b>

{loop$keywo rds$keyword}

<ahref="{APP_PAT H}index.php?m=content&c=tag&catid={$catid}&tag={urlencode($keyword)}"class="blue">{$keyword}</a>

{/loop}

{/loop}

{/pc}

14.每当列表几行的时候出现一次某些符号比如首页里面的文章推荐一行显示两条在这两条中间想加一条竖线|就用到这个代码了

数量大的话就容易出错因为模运算嘛~~呵呵丌过一般也就4个标题以下

{pc:content action="position"posid="8"order="listorder DESC" num="2"}

{loop$data $r}

<a style="color:#040605" title="{$r[title]}" href="{$r[url]}"target=_blank>{str_cut($r[title],26,'')}</a>{if$n%2==1} |{/if}

{/loop}

{/pc}

15.v9列表页完美支持自定义段调用

{pc:content action="lists"catid="$catid" num="25"order="id DESC"page="$page"m ore info="1"}

{loop$data $r}

<a href="{$r[url]}">[{$r['字段名']}]>{$r[title]}</a>

{/loop}

<div class="pagebar">{$pages}</div>

{/pc}

16.当前栏目调用父级及以下栏目信息方法

其他代码该咋地还是要咋地。这是要素

{php$a rrch i ld id=$CAT EGO RYS[$CAT[pa rentid]][a rrchild id]}

{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行

howmessage(L('thanks'),APP_PATH)

修改成如下代码即可实现自动返回前一页howmessage(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"}<ul>

{loop$data $key$val}

<l i><a href="{$val['url']}">{$val['title']}</a>

<br>价格 {str_cut($v['自定义段'],100)} //100是字数

</li>

{/loop}

</ul>

{/pc}

第2页/(共2页)

第二种推荐位调用自定义字段

在模型里加好自定义字段后必须把“在推荐位标签中调用”点击“是“

然后用同一样的方法去调节数据就OK了记住如果你加了文章必须去更新文章才会显示自定义段在推荐中叧显示你选择后选择前加的加文章丌显示更新一下文章就显示了

例子

{pc:content action="position"pos id="推荐位id" num="30" thum b="1"moreinfo="1"order="listorder DESC"}

{loop$data $key$val}

<LI><a href="{$va l['url']}" ta rget="_bla nk"><img src="{$va l['自定义段']}"alt="{$val['title']}" height=36 width=98/></a>

<a href="{$val['url']}" target="_blank">{str_cut($val['title'],20)}</a></LI>{/loop}

{/pc}

20.编辑器上传图片自动使用标题作为alt参数

一修改statics/js/ckeditor/plugins/image/dia logs/image.j

找到accessKey: 'T','default' : ''

替换成accessKey: 'T','default' :$('#title').val()

二清除浏览器缓存

21.增加文章的随机点击数

找到100行的$views=$r['views']+1

修改为:

$rand_nums=rand(79,186)

$views=$r['views']+$ra nd_num

表示点击一次,增加79到186次丌等

-------------------------------------------------------------tips 某些版本出错民间解决方法

1.缩略图以及图集无法上传

/phpcms/libs/classes/attachment.class.ph

请把24行的也有可能是23行

$this->upload_func='copy'

改成

$this->upload_func='move_uploaded_file'

2.碎片模块搜索文章看丌到栏目

hpcms/modules/block/templates/search_content.tpl.ph

13行改成

<td><?phif(isset($_GET['dosubmit'])){?><div class="rt"><ahref="javascript:void(0)"oncl ic k="$('#search').toggle()"><?phecho L('folded_up_in_search_of')?></a></div><?php}echo form: :select_category('', $catid, 'name="catid" id="catid"', '',

'', '0', 1)?></td>

22、 PHPCMS V9的get标签调用

1、调用本系统单条数据示例调用ID为1的信息标题长度丌超过25个汉字显示更新日期 

{get sql="select*from phpcms_content where contentid=1" /}

标题 {str_cut($r[title], 50)}U RL  {$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 byupdatetime desc" rows="10"}

标题 {str_cut($r[title], 50)}U RL  {$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 byupdatetime desc" rows="10"page="$page"}

标题 {str_cut($r[title], 50)}U RL  {$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 byupdatetime desc" rows="10" return="v"}

标题 {str_cut($v[title], 50)}U RL  {$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 datelined e s c" rows="10"}

主题 {str_cut($r[subject],50)}URL http://bbs.phpcms.cn/viewthread.php?tid={$r[tid]}更新日期 {date('Y-m-d',$r[datel ine])}

{/get}

6、调用外部数据示例调用数据源为bbs 分类ID为1的10个最新主题主题长度丌超过25个汉字显示更新日期 

{get dbsource="bbs"sql="select*from cdb_threads where fid=1 order by datelined e s c" rows="10"}

主题 {str_cut($r[subject],50)}URL http://bbs.phpcms.cn/viewthread.php?tid={$r[tid]}更新日期 {date('Y-m-d',$r[datel ine])}

{/get}

丌知道有没有朋友在使用中遇到这几种方法丌能满足需求的时候呢

例如取出评论数最多的第3条到第10条记录有人说我是多此一丼一般取最多评论没理由丌取第一和第二条因为PHPCMS的缩略图对4 3这样的尺寸比较好对长条形如34的图片缩略效果丌好为了自己手动更新评论最多的第一和第二条记录故此丌想自动更新读取前两条。

<ul>

<!--{get sql="select

A.contentid,A.catid,A.title,A.th`um b,A.description`,A.url,A.status,A.updatetime,B.conten`tid,B.hits,B.comments f`rom phpcms_content as A INNER JOINphpcms_content_count as B ON A.contentid=B.contentid and A.status=99 andLENGTH(A.thumb)>0 order by B.comments desc LIMIT 3,7"}-->

<l i><span class="xxnse_fen2">{$r[comments]}人参不评论</span>·<ahref="{$r[url]}" title="{$r[title]}">{str_cut($r[title], 28)}</a></li>

<!--{/get}-->

</ul>

关键点就在order by B.comments desc LIMIT 3,7 表示从第3条记录开始向下读取7条数据这个在MY SQ L是经常用我抱着试试看的想法结果是可以的。效果如下

希望做PH PCMS开发的朋友共同学习和分享hpcms V9保留了2008的get标签的使用方法

它包括了2种方式一种是内部数据另一种是外部数据

我们先分析下内部数据的使用方法

1、内部数据的调用

{pc:get sql="SELECT*FROM`XX`WHERE fid=$ltid AND digest=2 ANDifupload=1 ORDER BY tid DESC" num="2"cache="3600" return="data" }{loop$data $r}

。 。 。 。 。

/loop

{/pc}

由此可以看出get语句支持num的用法但是丌支持limit 5  5.这样的用法实在是很遗憾um是调用的条数

2、外部数据的调用

{pc:get sql="SELECT*FROM phpcms_member"cache="3600"age="$page"dbsource="discuz" return="data"}

<ul>

{loop$data $key$val}

{$val [ username]}<br/>

IMIDC彩虹数据:日本站群多ip服务器促销;30Mbps带宽直连不限流量,$88/月

imidc怎么样?imidc彩虹数据或彩虹网络现在促销旗下日本多IP站群独立服务器,原价159美元的机器现在只需要88美元,而且给13个独立IPv4,30Mbps直连带宽,不限制月流量!IMIDC又名为彩虹数据,rainbow cloud,香港本土运营商,全线产品都是商家自营的,自有IP网络资源等,提供的产品包括VPS主机、独立服务器、站群独立服务器等,数据中心区域包括香港、日本、台湾、美国和南非...

digital-vm$80/月,最高10GDigital-VM1Gbps带宽带宽

digital-vm在日本东京机房当前提供1Gbps带宽、2Gbps带宽、10Gbps带宽接入的独立服务器,每个月自带10T免费流量,一个独立IPv4。支持额外购买流量:20T-$30/月、50T-$150/月、100T-$270美元/月;也支持额外购买IPv4,/29-$5/月、/28-$13/月。独立从下单开始一般24小时内可以上架。官方网站:https://digital-vm.com/de...

享有云:美国BGP云服务器低至20元/月起,首月打折;香港2核2G2M仅50元/月起

享有云怎么样?享有云是一家新的国内云服务器商家,目前提供国内、香港及海外地区的云服务器,拥有多线路如:BGP线路、CN2线路、高防等云服务器,并且提供稳定、安全、弹性、高性能的云端计算服务,实时满足您的多样性业务需求。目前,美国bgp云服务器,5M带宽,低至20元/月起,270元/年起,首月打折;香港2核2G2M仅50元/月起,450元/年起!点击进入:享有云官方网站地址享有云优惠活动:一、美国B...

phpcms模板为你推荐
操作httphttp500ZTCS500在哪能下载手机QQ?accessdenied重装时系统都会提示access denied中国企业信息网哪个查询企业信息的网站收录的企业信息最多人人视频总部基地落户重庆2019.5.30号以后重庆有了新的迁入户口政策,请问外省户口以一般人才方式迁入重庆,可以按揭买房吗ldapserverLDAP3是什么大飞资讯单仁资讯的黄功夫是何许人?三友网网测是什么意思?银花珠树晓来看谜语白色花无人栽一夜北风遍地开。旡根无叶又无枝不知是谁送花来。谜底是什么zhuo爱timi什么意思
美国虚拟主机空间 虚拟主机控制面板 美国加州vps ipage 冰山互联 arvixe 秒解服务器 免费博客空间 howfile 宁波服务器 adroit 中国网通测速 vip域名 512mb 便宜空间 西安主机 买空间网 域名和主机 七牛云存储 google搜索打不开 更多