本文實例講述了Smarty日期時間操作方法。分享給大家供大家參考,具體如下:
$smarty = new Smarty; $smarty->assign('yesterday', strtotime('-1 day')); $smarty->display('index.tpl');
index.tpl:
{$smarty.now|date_format} //Sep 7, 2009 {$smarty.now|date_format:"%A, %B %e, %Y"} {$smarty.now|date_format:"%H:%M:%S"} {$yesterday|date_format} {$yesterday|date_format:"%A, %B %e, %Y"} {$yesterday|date_format:"%H:%M:%S"}
Smarty顯示格式化當前日期
{$smarty.now|date_format} {$smarty.now|date_format:"%A, %m %e, %Y"} {$smarty.now|date_format:"%H:%M:%S"}
smarty符號說明
%Y表示年份
%m表示月份
%d表示日
%A 表示星期幾,
%H 表示小時
%M表示分鐘
%s表示秒
如果日期是變量,可以:
{$yesterday|date_format:"%A, %B %e, %Y"} {$yesterday|date_format:"%H:%M:%S"}
smarty內部日期函數html_select_date()使用說明
prefix string類型 默認前綴名為"Date_ start_year string類型 默認為當前年份 仍可以用(+/-N)模式表示 如start_year="-10" option就從1999年開始 end_year string類型 默認同上 可用(+/-N)模式表示 如end_year="+5" option就到2014為止 field_order string類型 默認MDY 即按月日年的順序 排放select month_format string類型 默認%B 即顯示為January、February、etc. %b格式為簡寫形式 顯示月份的前三個字母 %m格式為數字顯示月份 day_format string類型 默認%02d 數字表示從01~31 並且與月份不關聯 %b格式為二進制顯示格式 很少用
其他屬性:
display_days boolean類型 控制day的select是否顯示 display_months boolean類型 控制month的select是否顯示 display_years boolean類型 控制year的select是否顯示 year_as_text boolean類型 true顯示為text型年份 false顯示為下拉菜單型 reverse_years boolean 類型 true的情況下年份為倒序顯示 year_size string 類型 值在大於1的情況下均為下拉菜單型輸出 0或1時為上下箭頭控制 month_size 同上 day_size 同上
示例如下:
{html_select_date prefix="StartDate" time=$time start_year="-5" end_year="+1" display_days=false}
OUTPUT: (current year is 2009)
<select name="StartDateMonth"> <option value="1">January</option> <option value="2">February</option> <option value="3">March</option> <option value="4">April</option> <option value="5">May</option> <option value="6">June</option> <option value="7">July</option> <option value="8">August</option> <option value="9">September</option> <option value="10">October</option> <option value="11">November</option> <option value="12" selected>December</option> </select> <select name="StartDateYear"> <option value="1999">1995</option> <option value="1999">1996</option> <option value="1999">1997</option> <option value="1999">1998</option> <option value="1999">1999</option> <option value="2000" selected>2000</option> <option value="2001">2001</option> </select>
其他的屬性,請自行調試。這個日期處理函數的缺點是day與month不關聯,不如用js處理
其中js顯示day的函數可以如下定義:
function showdays(year,month){ var day="day"; if(month.value==0){ document.getElementById(day).length=1; return; }else{ if(month.value==1||month.value==3||month.value==5||month.value==7||month.value==8||month.value==10||month.value==12){ document.getElementById(day).length=1; createlist(1,32,day); return; }else if(month.value==2){ if(year.value%4==0&&year.value%100!=0||year.value%400==0){ document.getElementById(day).length=1; createlist(1,30,day); return; }else{ document.getElementById(day).length=1; createlist(1,29,day); return; } }else{ document.getElementById(day).length=1; createlist(1,31,day); return; } } }
更多關於Smarty相關內容感興趣的讀者可查看本站專題:《smarty模板入門基礎教程》、《PHP模板技術總結》、《PHP基於pdo操作數據庫技巧總結》、《PHP運算與運算符用法總結》、《PHP網絡編程技巧總結》、《PHP基本語法入門教程》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》
希望本文所述對大家基於smarty模板的PHP程序設計有所幫助。