date=new Date(year,month,day);轉(zhuǎn)換標準日期類型
創(chuàng)新互聯(lián)專注于平果企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè)公司,商城網(wǎng)站定制開發(fā)。平果網(wǎng)站建設(shè)公司,為平果等地區(qū)提供建站服務(wù)。全流程按需網(wǎng)站開發(fā),專業(yè)設(shè)計,全程項目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)
t=date.getTime();
x=t+(24*60*60*1000*365*n)//n為第2個框輸入的年數(shù),(天:x=t+(24*60*60*1000*n);
)
d=new Date();
d.setTime(x);
d就是值,改變成你要的格式就OK了
date=new Date(year,month,day);轉(zhuǎn)換標準日期類型 ?
t=date.getTime(); ?
x=t+(24*60*60*1000*365*n)//n為第2個框輸入的年數(shù),(天:x=t+(24*60*60*1000*n); ?
) ?
d=new Date(); ?
d.setTime(x); ?
d就是值,改變成你要的格式就OK了
[img]樹形菜單,熟悉Windows程序管理器的讀者一定不會陌生。單擊項目左側(cè)的+號,項目展開;再次單擊,項目收縮。讀過很多篇有關(guān)樹形菜單的JavaScript實現(xiàn)方法,原理很簡單,都是利用Style中display屬性的控制。筆者本文的重點并不側(cè)重于此,倒是想談一談如何實現(xiàn)每一次從數(shù)據(jù)庫中提取數(shù)據(jù)并動態(tài)更新樹形菜單。
樹形菜單主要用來導航。網(wǎng)站有很多欄目,每個欄目下有很多子欄目,欄目經(jīng)常變動,如增加新欄目,改變現(xiàn)有欄目名稱,調(diào)整主次欄目之間關(guān)系等等,如果每一次都去改動頁面代碼,非常不便。而且因為信息都存放在數(shù)據(jù)庫中,動態(tài)實現(xiàn)變得可能和必要。
本文并不側(cè)重理論,只是為大家提供自己的一段代碼,和大家一起來探討一下PHP實現(xiàn)問題。為了便于說明,筆者對數(shù)據(jù)庫作了一些改動,假設(shè)菜單字符串存放在menu表中,main字段存放主菜單字符串,sub字段存放子菜單字符串,subid字段存放子菜單標識。
?php
$DB = new My_DB();
$DB-query("select subid, main from menu group by main order by subid");
while ($DB-next_record()){
$Main[] = $DB-f("main");
$Key[] = $DB-f("subid");
}
/*首先,連接數(shù)據(jù)庫,查詢所謂的欄目名稱。以上代碼采用了PHPLib中的數(shù)據(jù)庫函數(shù),其中,$Main數(shù)組用來存放主菜單字符串,$Key數(shù)組用來存放子菜單關(guān)鍵字。大家可以采用多種方法,因人而異*/
for ($i=0;$icount($Main);$i++){
$j=0;
$DB-query("select sub, subid from menu where main='".$Main[$i]."'");
////利用query查詢出與當前主菜單匹配的所有子菜單字符串
?
/*以下代碼和HTML代碼結(jié)合到一起,大家看起來可能會不習慣,但這樣代碼顯得簡潔多了。為了模擬樹形菜單,筆者源程序中使用了幾個圖片文件,l.gif, m.gif和p.gif,并利用onMouse事件模擬菜單的動態(tài)效果。PHP語句主要是為Javascript制作標簽(tag)的id*/
table width="140" border="0" cellspacing="0" cellpadding="0" class="f14"
tr
td width="15"/td
td id="?php echo "m_".$Key[$i]; ?" width="9" height="21"img src="images/p.gif" width="9" height="21"/td
td
div style="cursor:hand" onclick="javascript:MakeMenu('?php echo $Key[$i]; ?')" onMouseOver="javascript:MakeShow('in')" onMouseOut="javascript:MakeShow('out')"??php echo $Main[$i]; ?/div
/td
/tr
tr id="?php echo "s_".$Key[$i]; ?" style="display:none"
td width="15"/td
td colspan="2"
table width="100%" border="0" cellspacing="0" cellpadding="0" class="f9"
?php
while ($DB-next_record()){
?
tr
td width="12"
img src="images/?php echo ++$j==$DB-nf()?"l.gif":"t.gif"; ?" width="12" height="21"/td
////需要說明一下,$j變量在這里用來決定顯示什么圖片。此句的意思是,子菜單的最后一項顯示l.gif,其它項顯示t.gif
td??php echo "a href=\"yoururl\"yourstr/a";?/td
/tr
?php
}
?
/table
/td
/tr
/table
?php
}
?
到此為止,PHP的使命已經(jīng)結(jié)束,大家可以把代碼運行一下,看看輸出是什么??偠灾?,它的輸出結(jié)果正是樹形菜單所要的結(jié)構(gòu)。下面我們需要構(gòu)造Javascript代碼。很簡單,我不打算作向詳細的描述。
script language="javascript1.2"
!--
function MakeMenu(id){
mid="m_"+id;
sid="s_"+id;
with (document){
if (all(sid).style.display=="none"){
all(sid).style.display="";
all(mid).innerHTML="img src='images/m.gif' width='9' height='21'";
}else{
all(sid).style.display="none";
all(mid).innerHTML="img src='images/p.gif' width='9' height='21'";
}
}
}
function MakeShow(to){
with (document){
if (to=='in'){
window.event.srcElement.style.color="red";
window.event.srcElement.style.fontWeight="bold";
}else{
window.event.srcElement.style.color="";
window.event.srcElement.style.fontWeight="";
}
}
}
--
/script
熟悉Javascript的讀者,以上代碼理解起來應(yīng)該不成問題。這段代碼的難點就在于PHP的實現(xiàn)部分,調(diào)試時遇到很大麻煩,總是提示Javascirpt錯誤。在排除萬難之后,把這段代碼奉獻給大家,希望能為大家以后的網(wǎng)頁設(shè)計工作節(jié)省一點寶貴的時間。
一、為什么Javascript有設(shè)計缺陷?
這里有三個客觀原因,導致Javascript的設(shè)計不夠完善。
1. 設(shè)計階段過于倉促
Javascript的設(shè)計,其實只用了十天。而且,設(shè)計師是為了向公司交差,本人并不愿意這樣設(shè)計(參見《Javascript誕生記》)。
另一方面,這種語言的設(shè)計初衷,是為了解決一些簡單的網(wǎng)頁互動(比如,檢查"用戶名"是否填寫),并沒有考慮復(fù)雜應(yīng)用的需要。設(shè)計者做夢也想不到,Javascript將來可以寫出像Gmail這種極其龐大復(fù)雜的網(wǎng)頁。
2. 沒有先例
Javascript同時結(jié)合了函數(shù)式編程和面向?qū)ο缶幊痰奶攸c,這很可能是歷史上的第一例。而且直到今天為止,Javascript仍然是世界上唯一使用Prototype繼承模型的主要語言。這使得它沒有設(shè)計先例可以參考。
3. 過早的標準化
Javascript的發(fā)展非???,根本沒有時間調(diào)整設(shè)計。
1995年5月,設(shè)計方案定稿;10月,解釋器開發(fā)成功;12月,向市場推出,立刻被廣泛接受,全世界的用戶大量使用。Javascript缺乏一個從小到大、慢慢積累用戶的過程,而是連續(xù)的爆炸式擴散增長。大量的既成網(wǎng)頁和業(yè)余網(wǎng)頁設(shè)計者的參與,使得調(diào)整語言規(guī)格困難重重。
更糟的是,Javascript的規(guī)格還沒來及調(diào)整,就固化了。
1996年8月,微軟公司強勢介入,宣布推出自己的腳本語言Jscript;11月,為了壓制微軟,網(wǎng)景公司決定申請Javascript的國際標準;1997年6月,第一個國際標準ECMA-262正式頒布。
也就是說,Javascript推出一年半之后,國際標準就問世了。設(shè)計缺陷還沒有充分暴露就成了標準。相比之下,C語言問世將近20年之后,國際標準才頒布。
二、Javascript的10個設(shè)計缺陷
1. 不適合開發(fā)大型程序
Javascript沒有名稱空間(namespace),很難模塊化;沒有如何將代碼分布在多個文件的規(guī)范;允許同名函數(shù)的重復(fù)定義,后面的定義可以覆蓋前面的定義,很不利于模塊化加載。
2. 非常小的標準庫
Javascript提供的標準函數(shù)庫非常小,只能完成一些基本操作,很多功能都不具備。
3. null和undefined
null屬于對象(object)的一種,意思是該對象為空;undefined則是一種數(shù)據(jù)類型,表示未定義。
typeof null; // object
typeof undefined; // undefined
兩者非常容易混淆,但是含義完全不同。
var foo;
alert(foo == null); // true
alert(foo == undefined); // true
alert(foo === null); // false
alert(foo === undefined); // true
在編程實踐中,null幾乎沒用,根本不應(yīng)該設(shè)計它。
4. 全局變量難以控制
Javascript的全局變量,在所有模塊中都是可見的;任何一個函數(shù)內(nèi)部都可以生成全局變量,這大大加劇了程序的復(fù)雜性。
a = 1;
(function(){
b=2;
alert(a);
})(); // 1
alert(b); //2
5. 自動插入行尾分號
Javascript的所有語句,都必須以分號結(jié)尾。但是,如果你忘記加分號,解釋器并不報錯,而是為你自動加上分號。有時候,這會導致一些難以發(fā)現(xiàn)的錯誤。
比如,下面這個函數(shù)根本無法達到預(yù)期的結(jié)果,返回值不是一個對象,而是undefined。
function(){
return
{
i=1
};
}
原因是解釋器自動在return語句后面加上了分號。
function(){
return;
{
i=1
};
}
6. 加號運算符
+號作為運算符,有兩個含義,可以表示數(shù)字與數(shù)字的和,也可以表示字符與字符的連接。
alert(1+10); // 11
alert("1"+"10"); // 110
如果一個操作項是字符,另一個操作項是數(shù)字,則數(shù)字自動轉(zhuǎn)化為字符。
alert(1+"10"); // 110
alert("10"+1); // 101
這樣的設(shè)計,不必要地加劇了運算的復(fù)雜性,完全可以另行設(shè)置一個字符連接的運算符。
7. NaN
NaN是一種數(shù)字,表示超出了解釋器的極限。它有一些很奇怪的特性:
NaN === NaN; //false
NaN !== NaN; //true
alert( 1 + NaN ); // NaN
與其設(shè)計NaN,不如解釋器直接報錯,反而有利于簡化程序。
8. 數(shù)組和對象的區(qū)分
由于Javascript的數(shù)組也屬于對象(object),所以要區(qū)分一個對象到底是不是數(shù)組,相當麻煩。Douglas Crockford的代碼是這樣的:
if ( arr
typeof arr === 'object'
typeof arr.length === 'number'
!arr.propertyIsEnumerable('length')){
alert("arr is an array");
}
9. == 和 ===
==用來判斷兩個值是否相等。當兩個值類型不同時,會發(fā)生自動轉(zhuǎn)換,得到的結(jié)果非常不符合直覺。
"" == "0" // false
0 == "" // true
0 == "0" // true
false == "false" // false
false == "0" // true
false == undefined // false
false == null // false
null == undefined // true
" \t\r\n" == 0 // true
因此,推薦任何時候都使用"==="(精確判斷)比較符。
10. 基本類型的包裝對象
Javascript有三種基本數(shù)據(jù)類型:字符串、數(shù)字和布爾值。它們都有相應(yīng)的建構(gòu)函數(shù),可以生成字符串對象、數(shù)字對象和布爾值對象。
new Boolean(false);
new Number(1234);
new String("Hello World");
與基本數(shù)據(jù)類型對應(yīng)的對象類型,作用很小,造成的混淆卻很大。
alert( typeof 1234); // number
alert( typeof new Number(1234)); // object
關(guān)于Javascript的更多怪異行為,請參見Javascript Garden和wtfjs.com。
三、如何看待Javascript的設(shè)計缺陷?
既然Javascript有缺陷,數(shù)量還不少,那么它是不是一種很糟糕的語言?有沒有前途?
回答是Javascript并不算糟糕,相反它的編程能力很強大,前途很光明。
首先,如果遵守良好的編程規(guī)范,加上第三方函數(shù)庫的幫助,Javascript的這些缺陷大部分可以回避。
其次,Javascript目前是網(wǎng)頁編程的唯一語言,只要互聯(lián)網(wǎng)繼續(xù)發(fā)展,它就必然一起發(fā)展。目前,許多新項目大大擴展了它的用途,node.js使得Javascript可以用于后端的服務(wù)器編程,coffeeScript使你可以用python和ruby的語法,撰寫Javascript。
最后,只要發(fā)布新版本的語言標準(比如?ECMAscript 5),就可以彌補這些設(shè)計缺陷。當然,標準的發(fā)布和標準的實現(xiàn)是兩回事,上述的很多缺陷也許會一直伴隨到Javascript存在的最后一天。