久艹网,亚洲一日韩欧美中文字幕2019,国产欧美日韩精品专区黑人,一区二区三区久久99

中山php|最優(yōu)網(wǎng)絡(luò)中山做網(wǎng)站 中山php建站

最優(yōu)良人

2012/09/22 at 11:16

好用的smarty標(biāo)簽:capture,literal,fetch

1,capture標(biāo)簽

capture的中文意思是抓取,它的作用是抓取模板輸出的數(shù)據(jù),當(dāng)我們需要它的時(shí)候,調(diào)用它,以得到抓取數(shù)據(jù)的目的。例子:

  1. {capture?name=test}
  2. <img?src=”testimg.jpg”>
  3. {/capture}
  4. <div?class=”image”>
  5. {$smarty.capture.test}
  6. </div>

說(shuō)明:
在{capture name=”test”}和{/capture}之間的內(nèi)容被存儲(chǔ)到變量$test中,該變量由name屬性指定.在模板中通過(guò) $smarty.capture.test 訪問(wèn)該變量.如果沒(méi)有指定name 屬性,函數(shù)默認(rèn)將使用”default” 作為參數(shù),這一點(diǎn)很jquery中的clone

2,config_load標(biāo)簽

config_load可以直接將文件中的內(nèi)容讀取出來(lái),這樣可以省掉assign這一步。

  1. test.csv:
  2. pageTitle?=?”config_load_test”
  3. bodyBgColor?=?”#eeeeee”
  4. img?=?”girl.jpg”
  5. width=”100″
  6. height=”100″
  7. index.tpl:
  8. {config_load?file=”test.csv”}
  9. <html>
  10. <title>{#pageTitle#}</title>
  11. <body?bgcolor=”{#bodyBgColor#}”>
  12. <img?src=”{#img#}”?width=”{#width#}”?height=”{#height#}”>
  13. </body>
  14. </html>

上述過(guò)程中如果出現(xiàn)這樣的問(wèn)題Warning: Smarty error: unable to read resource, 請(qǐng)查看一下,你的test.csv是不是放在smarty的配置目錄中,默認(rèn)配置目錄是configs

  1. /**
  2. *?The?directory?where?config?files?are?located.
  3. *
  4. *?@var?string
  5. */
  6. var?$config_dir??????=??’configs’;

3,literal標(biāo)簽的使用

做web開(kāi)發(fā),難免會(huì)寫(xiě)一些JS,jquery代碼。js和jquery里面都會(huì){}這樣的符號(hào),smarty會(huì)不會(huì)把它理解成php的變量呢?如果你不加literal標(biāo)簽的話,smarty肯定會(huì)把它理解變量了,加了就不會(huì),例如:

  1. {literal}
  2. function?getAbsLeft(e){
  3. var?l=e.offsetLeft;
  4. while(e=e.offsetParent)l+=e.offsetLeft;
  5. return?l;
  6. }
  7. function?getAbsTop(e){
  8. var?t=e.offsetTop;
  9. while(e=e.offsetParent)t+=e.offsetTop;
  10. return?t;
  11. }
  12. {/literal}

4,php標(biāo)簽

當(dāng)你習(xí)慣了assign后,你有沒(méi)有想過(guò),在模板文件里面直接寫(xiě)php代碼呢,我想有的時(shí)候你肯定很想吧。例如:

  1. {php}
  2. global?$result;
  3. foreach($result?as?$key=>$value){
  4. echo?”key=$key,value=>$value<br>”;
  5. }
  6. {/php}

5,strip標(biāo)簽

strip標(biāo)簽去除標(biāo)簽內(nèi)的空格和回車,這一點(diǎn)我覺(jué)得,做手機(jī)開(kāi)發(fā)的朋友肯定用的到,因?yàn)槿强崭裼锌赡軙?huì)導(dǎo)致整個(gè)頁(yè)面錯(cuò)亂,甚至是一個(gè)空白頁(yè)面。手機(jī)屏幕小,估計(jì)用smarty的可能性也比較小。

  1. {strip}
  2. <div>
  3. <font?color=”red”>strip</font>
  4. </div>
  5. {/strip}

6,fetch標(biāo)簽

fetch標(biāo)簽根php的file_get_contents挺想的,都可以把文件中的內(nèi)容讀出來(lái),并且是個(gè)字符串的形勢(shì)

  1. {fetch?file=”./aaaa.txt”?assign=”result”}
  2. {if?is_array($result)}
  3. <b>is?array</b>
  4. {else?if}
  5. <b>not?array</b>
  6. {/if}

 

 

標(biāo)簽:
comments Comments (481)    -
2012/09/17 at 17:12

htaccess實(shí)現(xiàn)域名綁定,拒絕其他域名訪問(wèn)

獨(dú)立ip的主機(jī),只要其他域名指向該ip都是可以訪問(wèn)的,多域名訪問(wèn)會(huì)產(chǎn)生大量重復(fù)內(nèi)容,對(duì)seo非常不利,我們可以利用htaccess實(shí)現(xiàn)域名綁定,拒絕其他域名訪問(wèn)

在站點(diǎn)根目錄建立.htaccess文件,寫(xiě)入如下內(nèi)容:

RewriteEngine on
RewriteBase /
RewriteCond %{HTTP_HOST} !www.dgkai.cn [NC]
RewriteCond %{HTTP_HOST} !zui88.com [NC]
RewriteCond %{HTTP_HOST} !^$
RewriteRule ^.* – [F,L]

這樣實(shí)現(xiàn)的結(jié)果是只能通過(guò)www.dgkai.cn,zui88.com來(lái)訪問(wèn)站點(diǎn),用其他的HOST訪問(wèn)都會(huì)顯示403Forbidden。

其中:{HTTP_HOST}代表HTTP協(xié)議GET動(dòng)作同時(shí)傳遞的Host的值,[NC]代表忽略大小寫(xiě);[F]代表動(dòng)作為禁止;[L]代表最終匹配。

標(biāo)簽:
comments Comments (459)    -
2012/09/13 at 11:45

網(wǎng)站被百度k了怎么辦?被懲罰后如何恢復(fù)排名

網(wǎng)站被百度懲罰,兩個(gè)多月了,排名還沒(méi)有恢復(fù),蜘蛛爬行正常,收錄和快照也正常,應(yīng)該就是域名被降權(quán)處理了。

這么久時(shí)間過(guò)去了,排名還是沒(méi)有,說(shuō)明被百度降權(quán)的域名想恢復(fù)是多么不容易,很多站長(zhǎng)網(wǎng)站被降權(quán)后,做了很多補(bǔ)救工作,希望可以恢復(fù),其實(shí),我想百度數(shù)據(jù)庫(kù)肯定有無(wú)數(shù)的降權(quán)域名,想單單把你的域名拿出來(lái)恢復(fù)權(quán)重幾乎是不可能的,其實(shí)有一種有效的補(bǔ)救措施,不過(guò)代價(jià)比較大,就是被降權(quán)的域名直接不要了,換新的域名。

前天我做了一個(gè)嘗試,注冊(cè)了新域名 zui88.com ,把原來(lái)的域名zui88.com進(jìn)行301重定向,到了第二天新域名zui88.com被收錄,并且大部分關(guān)鍵詞排名恢復(fù),然后服務(wù)器被關(guān)閉,因?yàn)樾掠蛎麤](méi)有備案,今天正式把網(wǎng)站遷移到香港服務(wù)器,以后就使用新域名,老域名就做轉(zhuǎn)向用了。有待測(cè)試??!

 

標(biāo)簽:
comments Comments (475)    -
2012/08/21 at 16:55

新站如何能快速被百度收錄

剛剛做好的一個(gè)網(wǎng)站,如何能快速被百度收錄,并且可以查詢的到呢,個(gè)人以為有以下幾點(diǎn):

1,網(wǎng)站上線時(shí)必須至少有一點(diǎn)原創(chuàng)內(nèi)容支撐,可以先發(fā)一些新聞產(chǎn)品,公告通知,技術(shù)知識(shí)的文章,保障網(wǎng)站不會(huì)太空洞,避免完全復(fù)制網(wǎng)絡(luò)的內(nèi)容。

2,必須存放在一個(gè)相對(duì)干凈的主機(jī)空間,所謂干凈的主機(jī)空間就是該主機(jī)ip沒(méi)有被搜索引擎降權(quán),該ip下的其他網(wǎng)站沒(méi)有不良內(nèi)容或垃圾站,有可能的話盡量用一個(gè)獨(dú)立ip的空間,并且查一些該ip以前的使用情況。

3,必須有高質(zhì)量的外部導(dǎo)入鏈接,比如收錄良好的資訊類網(wǎng)站,發(fā)布一條公司介紹的信息,帶上公司的網(wǎng)址鏈接,如果該信息被收錄的話,那么網(wǎng)站很可能也已經(jīng)被順帶收錄了,應(yīng)該提供給了搜索引擎蜘蛛一個(gè)入口爬行到我們網(wǎng)站來(lái)

第三點(diǎn)尤為重要,我曾經(jīng)試過(guò)幫客戶發(fā)了一條信息,信息秒收,客戶站也被秒收。

標(biāo)簽:,
comments Comments (437)    -
2012/08/16 at 11:58

JS獲取file上傳文件路徑,后綴,大小,文件名

/**
*函數(shù)描述:獲取input type=file的圖像全路徑
* @obj input type=file的對(duì)象
**/
function getFullPath(obj)
{
if(obj)
{
//ie
if (window.navigator.userAgent.indexOf("MSIE")>=1)
{
obj.select();
return document.selection.createRange().text;
}
//firefox
else if(window.navigator.userAgent.indexOf("Firefox")>=1)
{
if(obj.files)
{
return obj.files.item(0).getAsDataURL();
}
return obj.value;
}
return obj.value;
}
}

 

<input type="file" onchange="document.getElementById('img').src=getFullPath(this);" >

 

=========================================================================

 

 

#判斷IE還是Firefox

function getFullPath(obj)

{

if(obj)

{

//ie

if (window.navigator.userAgent.indexOf("MSIE")>=1)

{

obj.select();

return document.selection.createRange().text;

}

//firefox

else if(window.navigator.userAgent.indexOf("Firefox")>=1)

{

if(obj.files)

{

return obj.files.item(0).getAsDataURL();

}

return obj.value;

}

return obj.value;

}

}

 

 

 

#判斷后綴名

function yulan(){

var filePath =getFullPath(document.getElementById('UpFile'));

var fileText =filePath.substring(filePath.lastIndexOf("."),filePath.length);

var fileName =fileText.toLowerCase();

if ((fileName!='.jpg')&&(fileName!='.gif')&&(fileName!='.jpeg')&&(fileName!='.png')&&(fileName!='.bmp'))

{

alert("對(duì)不起,系統(tǒng)僅支持標(biāo)準(zhǔn)格式的照片,請(qǐng)您調(diào)整格式后重新上傳,謝謝 !");

document.form1.UpFile.focus();

}

else

{

document.getElementById("preview").innerHTML="<img src='"+getFullPath(document.getElementById('UpFile'))+"' width=120 style='border:6px double #ccc'>";

}

}

 

 

#判斷文件大小

var Sys = {};

if(navigator.userAgent.indexOf("MSIE")>0) {

Sys.ie=true;

}

if(isFirefox=navigator.userAgent.indexOf("Firefox")>0){

Sys.firefox=true;

}

 

var maxLength = 5*1024*1024;

 

function checkFileChange(obj) {

var filesize = 0;

if(Sys.firefox){

filesize = obj.files[0].fileSize;

}else if(Sys.ie){

var filePath = obj.value;

var image=new Image();

image.src=filePath;

filesize=image.fileSize;

}

alert(filesize);

}

獲取文件名

firefox的input表單的value值默認(rèn)就可以獲取到文件名,而ie 則顯示文件路徑。

所以要區(qū)別對(duì)待,在firefox下 lastIndexOf('/')得到的是-1,而在ie下,目錄顯示的又是反斜杠,\,當(dāng)然在Linux
下,其他瀏覽器獲取到的又是正斜杠 / ( 暫時(shí)未證明有Linux下有瀏覽器file獲取到的值會(huì)是全路徑);
得用兩次判斷:

function getFileName(path){
var pos1 = path.lastIndexOf('/');
var pos2 = path.lastIndexOf('\\');
var pos = Math.max(pos1, pos2)
if( pos<0 )
return path;
else
return path.substring(pos+1);
}

返回不帶后綴的文件名

return name.substring(0,name.lastIndexOf('.'));

標(biāo)簽:,
comments Comments (184)    -
2012/08/01 at 17:36

ie6實(shí)現(xiàn)div頁(yè)面固定不動(dòng),純CSS中使用expression兼容fix

* html,* html body /* IE6 Fixed Position Jitter Fix */{background-image:url(about:blank);background-attachment:fixed;}
* html .fixed-top /* IE6 position fixed Top */{position:absolute;bottom:auto;top:expression(eval(document.documentElement.scrollTop));}
* html .fixed-right /* IE6 position fixed right */{position:absolute;right:auto;left:expression(eval(document.documentElement.scrollLeft+document.documentElement.clientWidth-this.offsetWidth)-(parseInt(this.currentStyle.marginLeft,10)||0)-(parseInt(this.currentStyle.marginRight,10)||0));}
* html .fixed-bottom /* IE6 position fixed Bottom */{position:absolute;bottom:auto;top:expression(eval(document.documentElement.scrollTop+document.documentElement.clientHeight-this.offsetHeight-(parseInt(this.currentStyle.marginTop,10)||0)-(parseInt(this.currentStyle.marginBottom,10)||0)));}
* html .fixed-left /* IE6 position fixed Left */{position:absolute;right:auto;left:expression(eval(document.documentElement.scrollLeft));}

CSS中使用expression有ie才能識(shí)別。IE5及其以后版本支持在CSS中使用expression,用來(lái)把CSS屬性和
Javascript表達(dá)式關(guān)聯(lián)起來(lái),這里的CSS屬性可以是元素固有的屬性,也可以是自定義屬性。就是說(shuō)CSS屬性后面可以是一段Javascript
表達(dá)式,CSS屬性的值等于Javascript表達(dá)式計(jì)算的結(jié)果。 在表達(dá)式中可以直接引用元素自身的屬性和方法,也可以使用其他瀏覽器對(duì)象。這個(gè)表達(dá)式就好像是在這個(gè)元素的一個(gè)成員函數(shù)中一樣。

例子: 1.給元素固有屬性賦值 下面是定義container容器的寬度,如果<725就為自己的寬度,否則就等于725,相當(dāng)于max-width:725px;。   <style type="text/css" media="screen">   #container { width: expression((documentElement.clientWidth > 725) ? "725px" : "auto" ); }   </style>   2.給元素自定義屬性賦值 例如,消除頁(yè)面上的鏈接虛線框。 通常的做法是:   <a href="link1.htm" onfocus="this.blur()">link1</a>   <a href="link2.htm" onfocus="this.blur()">link2</a>   <a href="link3.htm" onfocus="this.blur()">link3</a>   粗看或許還體現(xiàn)不出采用expression的優(yōu)勢(shì),但如果你的頁(yè)面上有幾十甚至上百個(gè)鏈接,這時(shí)的你難道還會(huì)機(jī)械式地Ctrl+C,Ctrl+V么,何況兩者一比較,哪個(gè)產(chǎn)生的冗余代碼更多呢?   采用expression的做法如下:   <style type="text/css">   a {star : expression(this.onFocus=this.blur());}   </style>   <a href="link1.htm">link1</a>   <a href="link2.htm">link2</a>   <a href="link3.htm">link3</a>   說(shuō)明:里面的star就是自己任意定義的屬性,你可以隨自己喜好另外定義,接著包含在expression()里的語(yǔ)句就是JS腳本, 在自定義屬性與expression之間可別忘了還有一個(gè)引號(hào),因?yàn)閷?shí)質(zhì)還是CSS,所以放在style標(biāo)簽內(nèi),而非script內(nèi)。OK,這樣就很容易 地用一句話實(shí)現(xiàn)了頁(yè)面中的鏈接虛線框的消除。不過(guò)你先別得意,如果觸發(fā)的特效是CSS的屬性變化,那么出來(lái)的結(jié)果會(huì)跟你的本意有差別。例如你想隨鼠標(biāo)的移 進(jìn)移出而改變頁(yè)面中的文本框顏色更改,你可能想當(dāng)然的會(huì)認(rèn)為應(yīng)該寫(xiě)為   <style type="text/css">   input {star : expression(onmouseover=this.style.backgroundColor="#F5F5F5";   onmouseout=this.style.backgroundColor="#FFFFFF")}   </style>   <input type="text">   <input type="text">   <input type="text">   可結(jié)果卻是出現(xiàn)腳本出錯(cuò),正確的寫(xiě)法應(yīng)該把CSS樣式的定義寫(xiě)進(jìn)函數(shù)內(nèi),如下所示:   <style type="text/css">   input {star : expression(onmouseover=function()   {this.style.backgroundColor="#FF0000"},   onmouseout=function(){this.style.backgroundColor="#FFFFFF"}) }   </style>   <input type="text">   <input type="text">   <input type="text">   注意:不是非常需要,一般不建議使用expression,因?yàn)閑xpression對(duì)瀏覽器資源要求比較高。



標(biāo)簽:, ,
comments Comments (437)    -
2012/07/21 at 12:35

JS 把字符串轉(zhuǎn)成整數(shù)的函數(shù)

parseInt()把字符串轉(zhuǎn)成整數(shù)

parseFloat()把字符串轉(zhuǎn)成浮點(diǎn)數(shù)

js在處理變量的數(shù)學(xué)運(yùn)算時(shí)一點(diǎn)要注意變量類型的轉(zhuǎn)換

JS 字符串轉(zhuǎn)整數(shù) JS 字符串轉(zhuǎn)整數(shù)方法主要有三種轉(zhuǎn)換函數(shù)、強(qiáng)制類型 轉(zhuǎn)換、利用js 變量弱類型轉(zhuǎn)換。

1.轉(zhuǎn)換函數(shù): js 提供了parseInt()和parseFloat()兩個(gè)轉(zhuǎn)換函數(shù)。

前者把值轉(zhuǎn)換成整 數(shù),后者把值轉(zhuǎn)換成浮點(diǎn)數(shù)。只有對(duì)String 類型調(diào)用這些方法,這兩個(gè)函數(shù)才 能正確運(yùn)行;對(duì)其他類型返回的都是NaN(Not aNumber)。 在判斷字符串是否是數(shù)字值前,parseInt()和parseFloat()都會(huì)仔細(xì)分析 該字符串。 parseInt()方法首先查看位置0 處的字符,判斷它是否是個(gè)有效數(shù)字;如 果不是,該方法將返回NaN,不再繼續(xù)執(zhí)行其他操作。但如果該字符是有效數(shù) 字,該方法將查看位置1 處的字符,進(jìn)行同樣的測(cè)試。這一過(guò)程將持續(xù)到發(fā)現(xiàn) 非有效數(shù)字的字符為止,此時(shí) parseInt()將把該字符之前的字符串轉(zhuǎn)換成數(shù)字。

例如,如果要把字符串"1234blue"轉(zhuǎn)換成整數(shù),那么parseInt()將返回 1234,因?yàn)楫?dāng)它檢測(cè)到字符b 時(shí),就會(huì)停止檢測(cè)過(guò)程。 字符串中包含的數(shù)字字面量會(huì)被正確轉(zhuǎn)換為數(shù)字,因此字符串"0xA"會(huì)被正 確轉(zhuǎn)換為數(shù)字10。 不過(guò),字符串"22.5"將被轉(zhuǎn)換成22,因?yàn)閷?duì)于整數(shù)來(lái)說(shuō),小數(shù)點(diǎn)是無(wú)效字 符。 一些示例如下: Js 代碼parseInt("1234blue");//returns 1234parseInt("0xA"); //returns 10parseInt("22.5");//returns 22parseInt("blue");//returns NaNparseInt()方法還有基模式,可以把二進(jìn)制、八進(jìn)制、十六進(jìn)制或其他任何 進(jìn)制的字符串轉(zhuǎn)換成整數(shù)。 基是由parseInt()方法的第二個(gè)參數(shù)指定的,所以要解析十六進(jìn)制的值, 需如下調(diào)用parseInt()方法: Js 代碼parseInt("AF",16);//returns 175 當(dāng)然,對(duì)二進(jìn)制、八進(jìn)制, 甚至十進(jìn)制(默認(rèn)模式),都可以這樣調(diào)用parseInt()方法: Js 代碼parseInt("10",2);//returns 2parseInt("10",8);//returns 8parseInt("10",10);//returns 10 如果十進(jìn)制數(shù)包含前導(dǎo)0,那么最好采用 基數(shù)10,這樣才不會(huì)意外地得到八進(jìn)制的值。

例如: Js 代碼parseInt("010");//returns 8parseInt("010",8);//returns 8parseInt("010",10);//returns 10 在這段代碼中,兩行代碼都把字符串 "010"解析成了一個(gè)數(shù)字。第一行代碼把這個(gè)字符串看作八進(jìn)制的值,解析它的 方式與第二行代碼(聲明基數(shù)為8)相同。最后一行代碼聲明基數(shù)為10,所以 iNum3 最后等于10。 parseFloat()方法與parseInt()方法的處理方式相似,從位置0 開(kāi)始查看 每個(gè)字符,直到找到第一個(gè)非有效的字符為止,然后把該字符之前的字符串轉(zhuǎn) 換成數(shù)字。

不過(guò),對(duì)于這個(gè)方法來(lái)說(shuō),第一個(gè)出現(xiàn)的小數(shù)點(diǎn)是有效字符。如果有兩個(gè) 小數(shù)點(diǎn),第二個(gè)小數(shù)點(diǎn)將被看作無(wú)效的,parseFloat()方法會(huì)把這個(gè)小數(shù)點(diǎn)之 前的字符串轉(zhuǎn)換成數(shù)字。這意味著字符串"22.34.5"將被解析成22.34。 使用parseFloat()方法的另一不同之處在于,字符串必須以十進(jìn)制形式表 示浮點(diǎn)數(shù),而不能用八進(jìn)制形式或十六進(jìn)制形式。 該方法會(huì)忽略前導(dǎo)0,所以八進(jìn)制數(shù)0908 將被解析為908。對(duì)于十六進(jìn)制 數(shù)0xA,該方法將返回NaN,因?yàn)樵诟↑c(diǎn)數(shù)中,x 不是有效字符。 此外,parseFloat()也沒(méi)有基模式。 下面是使用parseFloat()方法的示例: Js 代碼parseFloat("1234blue");//returns 1234.0 parseFloat("0xA"); //returns NaNparseFloat("22.5");//returns 22.5parseFloat("22.34.5"); //returns 22.34parseFloat("0908");//returns 908parseFloat("blue"); //returns NaN2.強(qiáng)制類型轉(zhuǎn)換 還可使用強(qiáng)制類型轉(zhuǎn)換(type casting)處理轉(zhuǎn)換值的類型。使用強(qiáng)制類型 轉(zhuǎn)換可以訪問(wèn)特定的值,即使它是另一種類型的。

ECMAScript 中可用的3 種強(qiáng)制類型轉(zhuǎn)換如下: Boolean(value)--把給定的值轉(zhuǎn)換成Boolean 型;Number(value)--把給定 的值轉(zhuǎn)換成數(shù)字(可以是整數(shù)或浮點(diǎn)數(shù));String(value)--把給定的值轉(zhuǎn)換成字 符串。 用這三個(gè)函數(shù)之一轉(zhuǎn)換值,將創(chuàng)建一個(gè)新值,存放由原始值直接轉(zhuǎn)換成的 值。這會(huì)造成意想不到的后果。 當(dāng)要轉(zhuǎn)換的值是至少有一個(gè)字符的字符串、非0 數(shù)字或?qū)ο?下一節(jié)將討論 這一點(diǎn))時(shí),Boolean()函數(shù)將返回true。如果該值是空字符串、數(shù)字0、 undefined 或null,它將返回false。 可以用下面的代碼段測(cè)試Boolean 型的強(qiáng)制類型轉(zhuǎn)換。 Js 代碼Boolean("");//false– empty stringBoolean("hi");//true– non-empty stringBoolean(100);//true– non-zero numberBoolean(null); //false-nullBoolean(0);//false-zeroBoolean(new Object());//true– objectNumber()的強(qiáng)制類型轉(zhuǎn)換與parseInt()和parseFloat()方法的處理方式 相似,只是它轉(zhuǎn)換的是整個(gè)值,而不是部分值。 還記得嗎,parseInt()和parseFloat()方法只轉(zhuǎn)換第一個(gè)無(wú)效字符之前的 字符串,因此"4.5.6"將被轉(zhuǎn)換為"4.5"。 用Number()進(jìn)行強(qiáng)制類型轉(zhuǎn)換,"4.5.6"將返回NaN,因?yàn)檎麄€(gè)字符串值不 能轉(zhuǎn)換成數(shù)字。 如果字符串值能被完整地轉(zhuǎn)換,Number()將判斷是調(diào)用parseInt()方法還 是調(diào)用parseFloat()方法。 下表說(shuō)明了對(duì)不同的值調(diào)用Number()方法會(huì)發(fā)生的情況: 用法結(jié)果 Js 代碼 Number(false)0Number(true)1Number(undefined)NaNNumber(null)0Number("5 .5")5.5Number("56")56Number("5.6.7")NaNNumber(new Object())NaNNumber(100)100 最后一種強(qiáng)制類型轉(zhuǎn)換方法 String()是最簡(jiǎn)單的, 因?yàn)樗砂讶魏沃缔D(zhuǎn)換成字符串。

要執(zhí)行這種強(qiáng)制類型轉(zhuǎn)換,只需要調(diào)用作為參數(shù)傳遞進(jìn)來(lái)的值的 toString()方法,即把1 轉(zhuǎn)換成"1",把true 轉(zhuǎn)換成"true",把false 轉(zhuǎn)換成 "false",依此類推。 強(qiáng)制轉(zhuǎn)換成字符串和調(diào)用toString()方法的唯一不同之處在于,對(duì)null 或undefined 值強(qiáng)制類型轉(zhuǎn)換可以生成字符串而不引發(fā)錯(cuò)誤: Js 代碼var s1=String(null);//"null"var oNull=null;var s2=oNull.toString();//won't work,causes an error3.利用js 變量弱類型 轉(zhuǎn)換 舉個(gè)小例子,一看,就會(huì)明白了。 Js 代碼script var str='012.345';var x=str-0;x=x*1;/script 上例 利用了js 的弱類型的特點(diǎn),只進(jìn)行了算術(shù)運(yùn)算,實(shí)現(xiàn)了字符串到數(shù)字的類型轉(zhuǎn) 換,不過(guò)這個(gè)方法還是不推薦的。

標(biāo)簽:
comments Comments (459)    -
2012/07/21 at 09:41

smarty 利用@ 在模版完整打印多維數(shù)組

有時(shí)候我們希望直接在模版上打印數(shù)組變量以供調(diào)試,打印的方式可以用php自帶的print_r或者是自己寫(xiě)的調(diào)試函數(shù),如debug().

如果直接這樣打印多維數(shù)組 {{$var|print_r}},在模版看到的結(jié)果會(huì)是遍歷后的所有的value,不會(huì)顯示完整的數(shù)組結(jié)構(gòu),正確的方法是在函數(shù)前加個(gè)@,意思是把變量作為整體去對(duì)待

{{$var|@print_r}}

標(biāo)簽:
comments Comments (613)    -
2012/07/14 at 15:41

php利用谷歌實(shí)現(xiàn)自動(dòng)在線翻譯

php利用谷歌實(shí)現(xiàn)自動(dòng)翻譯,以下是兩種實(shí)現(xiàn)的方式,php文檔用utf8就不會(huì)出現(xiàn)亂碼問(wèn)題

第一種利用curl:

function translate($text,$language='zh-cn|en'){
if(empty($text))return false;
@set_time_limit(0);
$html = "";
$ch=curl_init("http://google.com/translate_t?langpair=".urlencode($language)."&text=".urlencode($text));
curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);
curl_setopt($ch,CURLOPT_HEADER, 0);
curl_setopt($ch,CURLOPT_FOLLOWLOCATION,1);
$html=curl_exec($ch);
if(curl_errno($ch))$html = "";
curl_close($ch);
if(!empty($html)){
$x=explode("</span></span></div></div>",$html);
$x=explode("onmouseout=\"this.style.backgroundColor='#fff'\">",$x[0]);
return $x[1];
}else{
return false;
}
}
echo translate('去');
第二種:利用get方式
function googleTran($text){
if(empty($text)) return "";
//反間碟
$wf=@file_get_contents('http://translate.google.cn/translate_t?sl=zh-CN&tl=en&text='.$text.'#');
if (false===$wf||empty($wf)){
return false;
}

//截取相關(guān)信息
$return = "";

$star="style.backgroundColor='\#fff'\">";

$end="</span></span></div>";
$p = "#{$star}(.*){$end}#iU";//i表示忽略大小寫(xiě),U禁止貪婪匹配
if(preg_match_all($p,$wf,$rs))
{ print_r($rs);
return $rs[1][0];}

}

echo googleTran('去');

comments Comments (249)    -
2012/06/27 at 11:42

php,js判斷網(wǎng)站是不是手機(jī)訪問(wèn)

PHP中用以下代碼:

$uAgent = $_SERVER['HTTP_USER_AGENT'];

$osPat = "mozilla|m3gate|winwap|openwave|Windows NT|Windows 3.1|95|Blackcomb|98|ME|X Window|ubuntu|Longhorn|AIX|Linux|AmigaOS|BEOS|HP-UX|OpenBSD|FreeBSD|NetBSD|OS\/2|OSF1|SUN";

if(preg_match("/($osPat)/i", $uAgent )) //winwap 模擬WAP手機(jī)上網(wǎng)的一個(gè)瀏覽器; openwave|后面為各pc操作系統(tǒng)

{

echo "電腦訪問(wèn)";

}

else

{

echo "手機(jī)訪問(wèn)";

}

echo '<br/>'.$uAgent;
javascript中采用navigator.userAgent 來(lái)獲取,但非智能機(jī)似乎不支持js。

支持js的移動(dòng)客戶端還可以用以下代碼簡(jiǎn)單判斷是不是windows電腦訪問(wèn)的

if(navigator.platform.indexOf('Win32')!=-1){
//go to pc
}else{
// go to 手機(jī)
}

comments Comments (6)    -
欧美zozo| 2015AⅤ天堂| 97人妻在线视频| 美少妇| 木兰县| 久久久激情视频| 人鲁交yazhonghucxx| 天堂√在线中文最新版| 久久AV综合| 九九九九九伊人| 欧美综合国产精品久久丁香| 亚洲AV无码久久精品狠狠爱m| 亚洲 欧美 日韩 图片| 久久视频任我撸| 午夜偷拍精品视频免费观看| 99re8久久在热线播放| 亚洲色图色五月| 免费无码视频2| 亚洲一区二区三区无码中字视频 | 色吧 男人天堂| 久久极品在这里| 少妇与黑人4p| 亚洲av色噜噜男人的天堂| 欧美ffeesxhd熟妇| 久久精品国产精品亚洲艾草网 | 亚洲av无码一区二区三区不卡| 五月天四色| 黄色网址你懂的#| 都市风云超前超快最快更新| 日韩AV专区另类日韩AV另类| 人人插B| 少妇一级| 色五月婷婷影院| 国内久久| 尤物九九久久国产精品的分类| 一本色道久久88精品综合| 亚洲免费在线免费在线电影毛| 久久精品a亚洲| 在线播放一区| 欧美色综合又长又大| 囯产精品久久久久久久久久|