dedecms 57 采集目标文章的发布时间 采集后变成当前本地时间
这个很简单的 修改文章的发布时间 就可以了 可以更新到当前的 当然你要改到以前的 也可以实现的 这个我也不是很清楚 一般通过修改数据库吧!
本文实例讲述了dedecms自定义表单添加发布时间功能的方法。分享给大家供大家参考。具体实现方法如下:
dedecms自定义表单非常强大,可以做如报名系统、招聘系统、返修系统等等,唯一不好在于用户提交了表单之后,后台不显示提交时间
网上有一种方法是:
复制代码
代码如下:
<input name="shijian" id="shijian" value="{dede:php} echo $showtime=date("Y-m-d H:i:s");{/dede:php}">
但是我试了试结果却不尽人意,每次我提交表单时的时间都是一样的说明这个方法还是不行的,大家可以亲自测试;
所以我这里起点共享一个通过JS实现发布时间的方法,过程很简单:
1自定义表单添加一个文本字段(注意不是时间字段),如字段名“填写时间”,字段函数名“shijian”;
2在表单中时间字段中,按如下例子,加入JS代码:
http://wwwdede58com/a/dedejq/1630html
24小时内的时间显示红色:
[field:pubdate runphp='yes']
$a="<font color='#ff0000'>";
$b="</font>";
$c=strftime("%Y年%m月%d日 %H:%M:%S","@me");
$ntime = time();
$oneday = 3600 24;
if(($ntime - @me)<$oneday) @me = $a$c$b;
else @me =$c;
[/field:pubdate]
最后更新时间
{dede:tagname runphp='yes'}@me = date("Y-m-d H:i:s", time());{/dede:tagname}
XX天前
[field:pubdate runphp='yes']
$today = Floor(time()/(3600 24));
$senday= Floor(@me/(3600 24));
$updays = $today-$senday;
if($updays==0) @me = "今日";
else @me = $updays"天前";
[/field:pubdate]
利用strftime()函数将时间格式化:
%a 星期几的简写
%A 星期几的全称
%b 月分的简写
%B 月份的全称
%c 标准的日期的时间串
%C 年份的后两位数字
%d 十进制表示的每月的第几天
%D 月/天/年
%e 在两字符域中,十进制表示的每月的第几天
%F 年-月-日
%g 年份的后两位数字,使用基于周的年
%G 年分,使用基于周的年
%h 简写的月份名
%H 24小时制的小时
%I 12小时制的小时
%j 十进制表示的每年的第几天
%m 十进制表示的月份
%M 十时制表示的分钟数
%n 新行符
%p 本地的AM或PM的等价显示
%r 12小时的时间
%R 显示小时和分钟:hh:mm
%S 十进制的秒数
%t 水平制表符
%T 显示时分秒:hh:mm:ss
%u 每周的第几天,星期一为第一天 (值从0到6,星期一为0)
%U 第年的第几周,把星期日做为第一天(值从0到53)
%V 每年的第几周,使用基于周的年
%w 十进制表示的星期几(值从0到6,星期天为0)
%W 每年的第几周,把星期一做为第一天(值从0到53)
%x 标准的日期串
%X 标准的时间串
%y 不带世纪的十进制年份(值从0到99)
%Y 带世纪部分的十制年份
%z,%Z 时区名称,如果不能得到时区名称则返回空字符
更多介绍,可以阅读:网页链接
我已经解决了。现在把方法告诉你。都是我自己摸索出来的。。虽然我不知道什么意思。。。
下面是步骤:
1:找到 co_exportphp
然后找到这段代码:
else if($itemName == 'pubdate')
{
$pubdate = trim($ctag->GetInnerText());
if(preg_match("#[^0-9]#", $pubdate))
{
$pubdate = $sortrank = GetMkTime($pubdate);
}
/ else
{
$pubdate = $sortrank = time();
}
/
}
else if($itemName == 'litpic')
{
$litpic = trim($ctag->GetInnerText());
}
2然后干掉 / /之间的代码就OK了。
主要就是控制一下:listsize这个参数就可以了,如果只需要10页就设置成5,因为的参数会乘以2的方式来显示,如果是3,就是显示6个页码。 <div class="dede_pages"> <ul class="pagelist"> {dede:pagelist listitem="info,index,end,pre,next,pageno" listsize="5"/} </ul> </div><!-- /pages --> 希望对你有所帮助 PS:那你直接设置成4好了,显示8页,这样也可以啊。。。其实这些都是无所谓的。。只要没影响整体页面的布局就可以了(个人看法)
0条评论