2012/09/22 at 11:16
1,capture標簽
capture的中文意思是抓取,它的作用是抓取模板輸出的數據,當我們需要它的時候,調用它,以得到抓取數據的目的。例子:
- {capture?name=test}
- <img?src=”testimg.jpg”>
- {/capture}
- <div?class=”image”>
- {$smarty.capture.test}
- </div>
說明:
在{capture name=”test”}和{/capture}之間的內容被存儲到變量$test中,該變量由name屬性指定.在模板中通過 $smarty.capture.test 訪問該變量.如果沒有指定name 屬性,函數默認將使用”default” 作為參數,這一點很jquery中的clone
2,config_load標簽
config_load可以直接將文件中的內容讀取出來,這樣可以省掉assign這一步。
- test.csv:
- pageTitle?=?”config_load_test”
- bodyBgColor?=?”#eeeeee”
- img?=?”girl.jpg”
- width=”100″
- height=”100″
- index.tpl:
- {config_load?file=”test.csv”}
- <html>
- <title>{#pageTitle#}</title>
- <body?bgcolor=”{#bodyBgColor#}”>
- <img?src=”{#img#}”?width=”{#width#}”?height=”{#height#}”>
- </body>
- </html>
上述過程中如果出現(xiàn)這樣的問題Warning: Smarty error: unable to read resource, 請查看一下,你的test.csv是不是放在smarty的配置目錄中,默認配置目錄是configs
- /**
- *?The?directory?where?config?files?are?located.
- *
- *?@var?string
- */
- var?$config_dir??????=??’configs’;
3,literal標簽的使用
做web開發(fā),難免會寫一些JS,jquery代碼。js和jquery里面都會{}這樣的符號,smarty會不會把它理解成php的變量呢?如果你不加literal標簽的話,smarty肯定會把它理解變量了,加了就不會,例如:
- {literal}
- function?getAbsLeft(e){
- var?l=e.offsetLeft;
- while(e=e.offsetParent)l+=e.offsetLeft;
- return?l;
- }
- function?getAbsTop(e){
- var?t=e.offsetTop;
- while(e=e.offsetParent)t+=e.offsetTop;
- return?t;
- }
- {/literal}
4,php標簽
當你習慣了assign后,你有沒有想過,在模板文件里面直接寫php代碼呢,我想有的時候你肯定很想吧。例如:
- {php}
- global?$result;
- foreach($result?as?$key=>$value){
- echo?”key=$key,value=>$value<br>”;
- }
- {/php}
5,strip標簽
strip標簽去除標簽內的空格和回車,這一點我覺得,做手機開發(fā)的朋友肯定用的到,因為全角空格有可能會導致整個頁面錯亂,甚至是一個空白頁面。手機屏幕小,估計用smarty的可能性也比較小。
- {strip}
- <div>
- <font?color=”red”>strip</font>
- </div>
- {/strip}
6,fetch標簽
fetch標簽根php的file_get_contents挺想的,都可以把文件中的內容讀出來,并且是個字符串的形勢
- {fetch?file=”./aaaa.txt”?assign=”result”}
- {if?is_array($result)}
- <b>is?array</b>
- {else?if}
- <b>not?array</b>
- {/if}
標簽:
smarty
2012/09/17 at 17:12
獨立ip的主機,只要其他域名指向該ip都是可以訪問的,多域名訪問會產生大量重復內容,對seo非常不利,我們可以利用htaccess實現(xiàn)域名綁定,拒絕其他域名訪問
在站點根目錄建立.htaccess文件,寫入如下內容:
RewriteEngine on
RewriteBase /
RewriteCond %{HTTP_HOST} !m.jartj.cn [NC]
RewriteCond %{HTTP_HOST} !zui88.com [NC]
RewriteCond %{HTTP_HOST} !^$
RewriteRule ^.* – [F,L]
這樣實現(xiàn)的結果是只能通過m.jartj.cn,zui88.com來訪問站點,用其他的HOST訪問都會顯示403Forbidden。
其中:{HTTP_HOST}代表HTTP協(xié)議GET動作同時傳遞的Host的值,[NC]代表忽略大小寫;[F]代表動作為禁止;[L]代表最終匹配。
標簽:
htaccess
2012/09/13 at 11:45
網站被百度懲罰,兩個多月了,排名還沒有恢復,蜘蛛爬行正常,收錄和快照也正常,應該就是域名被降權處理了。
這么久時間過去了,排名還是沒有,說明被百度降權的域名想恢復是多么不容易,很多站長網站被降權后,做了很多補救工作,希望可以恢復,其實,我想百度數據庫肯定有無數的降權域名,想單單把你的域名拿出來恢復權重幾乎是不可能的,其實有一種有效的補救措施,不過代價比較大,就是被降權的域名直接不要了,換新的域名。
前天我做了一個嘗試,注冊了新域名 zui88.com ,把原來的域名zui88.com進行301重定向,到了第二天新域名zui88.com被收錄,并且大部分關鍵詞排名恢復,然后服務器被關閉,因為新域名沒有備案,今天正式把網站遷移到香港服務器,以后就使用新域名,老域名就做轉向用了。有待測試??!
標簽:
seo
2012/08/21 at 16:55
剛剛做好的一個網站,如何能快速被百度收錄,并且可以查詢的到呢,個人以為有以下幾點:
1,網站上線時必須至少有一點原創(chuàng)內容支撐,可以先發(fā)一些新聞產品,公告通知,技術知識的文章,保障網站不會太空洞,避免完全復制網絡的內容。
2,必須存放在一個相對干凈的主機空間,所謂干凈的主機空間就是該主機ip沒有被搜索引擎降權,該ip下的其他網站沒有不良內容或垃圾站,有可能的話盡量用一個獨立ip的空間,并且查一些該ip以前的使用情況。
3,必須有高質量的外部導入鏈接,比如收錄良好的資訊類網站,發(fā)布一條公司介紹的信息,帶上公司的網址鏈接,如果該信息被收錄的話,那么網站很可能也已經被順帶收錄了,應該提供給了搜索引擎蜘蛛一個入口爬行到我們網站來
第三點尤為重要,我曾經試過幫客戶發(fā)了一條信息,信息秒收,客戶站也被秒收。
標簽:
seo,
優(yōu)化
2012/08/16 at 11:58
/**
*函數描述:獲取input type=file的圖像全路徑
* @obj input type=file的對象
**/
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("對不起,系統(tǒng)僅支持標準格式的照片,請您調整格式后重新上傳,謝謝 !");
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值默認就可以獲取到文件名,而ie 則顯示文件路徑。
所以要區(qū)別對待,在firefox下 lastIndexOf('/')得到的是-1,而在ie下,目錄顯示的又是反斜杠,\,當然在Linux
下,其他瀏覽器獲取到的又是正斜杠 / ( 暫時未證明有Linux下有瀏覽器file獲取到的值會是全路徑);
得用兩次判斷:
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('.'));
標簽:
file,
js
2012/08/01 at 17:36
* 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才能識別。IE5及其以后版本支持在CSS中使用expression,用來把CSS屬性和
Javascript表達式關聯(lián)起來,這里的CSS屬性可以是元素固有的屬性,也可以是自定義屬性。就是說CSS屬性后面可以是一段Javascript
表達式,CSS屬性的值等于Javascript表達式計算的結果。 在表達式中可以直接引用元素自身的屬性和方法,也可以使用其他瀏覽器對象。這個表達式就好像是在這個元素的一個成員函數中一樣。
例子: 1.給元素固有屬性賦值 下面是定義container容器的寬度,如果<725就為自己的寬度,否則就等于725,相當于max-width:725px;。 <style type="text/css" media="screen"> #container { width: expression((documentElement.clientWidth > 725) ? "725px" : "auto" ); } </style> 2.給元素自定義屬性賦值 例如,消除頁面上的鏈接虛線框。 通常的做法是: <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)勢,但如果你的頁面上有幾十甚至上百個鏈接,這時的你難道還會機械式地Ctrl+C,Ctrl+V么,何況兩者一比較,哪個產生的冗余代碼更多呢? 采用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> 說明:里面的star就是自己任意定義的屬性,你可以隨自己喜好另外定義,接著包含在expression()里的語句就是JS腳本, 在自定義屬性與expression之間可別忘了還有一個引號,因為實質還是CSS,所以放在style標簽內,而非script內。OK,這樣就很容易 地用一句話實現(xiàn)了頁面中的鏈接虛線框的消除。不過你先別得意,如果觸發(fā)的特效是CSS的屬性變化,那么出來的結果會跟你的本意有差別。例如你想隨鼠標的移 進移出而改變頁面中的文本框顏色更改,你可能想當然的會認為應該寫為 <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"> 可結果卻是出現(xiàn)腳本出錯,正確的寫法應該把CSS樣式的定義寫進函數內,如下所示: <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,因為expression對瀏覽器資源要求比較高。
標簽:
CSS,
expression,
fix
2012/07/21 at 12:35
parseInt()把字符串轉成整數
parseFloat()把字符串轉成浮點數
js在處理變量的數學運算時一點要注意變量類型的轉換
JS 字符串轉整數 JS 字符串轉整數方法主要有三種轉換函數、強制類型 轉換、利用js 變量弱類型轉換。
1.轉換函數: js 提供了parseInt()和parseFloat()兩個轉換函數。
前者把值轉換成整 數,后者把值轉換成浮點數。只有對String 類型調用這些方法,這兩個函數才 能正確運行;對其他類型返回的都是NaN(Not aNumber)。 在判斷字符串是否是數字值前,parseInt()和parseFloat()都會仔細分析 該字符串。 parseInt()方法首先查看位置0 處的字符,判斷它是否是個有效數字;如 果不是,該方法將返回NaN,不再繼續(xù)執(zhí)行其他操作。但如果該字符是有效數 字,該方法將查看位置1 處的字符,進行同樣的測試。這一過程將持續(xù)到發(fā)現(xiàn) 非有效數字的字符為止,此時 parseInt()將把該字符之前的字符串轉換成數字。
例如,如果要把字符串"1234blue"轉換成整數,那么parseInt()將返回 1234,因為當它檢測到字符b 時,就會停止檢測過程。 字符串中包含的數字字面量會被正確轉換為數字,因此字符串"0xA"會被正 確轉換為數字10。 不過,字符串"22.5"將被轉換成22,因為對于整數來說,小數點是無效字 符。 一些示例如下: Js 代碼parseInt("1234blue");//returns 1234parseInt("0xA"); //returns 10parseInt("22.5");//returns 22parseInt("blue");//returns NaNparseInt()方法還有基模式,可以把二進制、八進制、十六進制或其他任何 進制的字符串轉換成整數。 基是由parseInt()方法的第二個參數指定的,所以要解析十六進制的值, 需如下調用parseInt()方法: Js 代碼parseInt("AF",16);//returns 175 當然,對二進制、八進制, 甚至十進制(默認模式),都可以這樣調用parseInt()方法: Js 代碼parseInt("10",2);//returns 2parseInt("10",8);//returns 8parseInt("10",10);//returns 10 如果十進制數包含前導0,那么最好采用 基數10,這樣才不會意外地得到八進制的值。
例如: Js 代碼parseInt("010");//returns 8parseInt("010",8);//returns 8parseInt("010",10);//returns 10 在這段代碼中,兩行代碼都把字符串 "010"解析成了一個數字。第一行代碼把這個字符串看作八進制的值,解析它的 方式與第二行代碼(聲明基數為8)相同。最后一行代碼聲明基數為10,所以 iNum3 最后等于10。 parseFloat()方法與parseInt()方法的處理方式相似,從位置0 開始查看 每個字符,直到找到第一個非有效的字符為止,然后把該字符之前的字符串轉 換成數字。
不過,對于這個方法來說,第一個出現(xiàn)的小數點是有效字符。如果有兩個 小數點,第二個小數點將被看作無效的,parseFloat()方法會把這個小數點之 前的字符串轉換成數字。這意味著字符串"22.34.5"將被解析成22.34。 使用parseFloat()方法的另一不同之處在于,字符串必須以十進制形式表 示浮點數,而不能用八進制形式或十六進制形式。 該方法會忽略前導0,所以八進制數0908 將被解析為908。對于十六進制 數0xA,該方法將返回NaN,因為在浮點數中,x 不是有效字符。 此外,parseFloat()也沒有基模式。 下面是使用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.強制類型轉換 還可使用強制類型轉換(type casting)處理轉換值的類型。使用強制類型 轉換可以訪問特定的值,即使它是另一種類型的。
ECMAScript 中可用的3 種強制類型轉換如下: Boolean(value)--把給定的值轉換成Boolean 型;Number(value)--把給定 的值轉換成數字(可以是整數或浮點數);String(value)--把給定的值轉換成字 符串。 用這三個函數之一轉換值,將創(chuàng)建一個新值,存放由原始值直接轉換成的 值。這會造成意想不到的后果。 當要轉換的值是至少有一個字符的字符串、非0 數字或對象(下一節(jié)將討論 這一點)時,Boolean()函數將返回true。如果該值是空字符串、數字0、 undefined 或null,它將返回false。 可以用下面的代碼段測試Boolean 型的強制類型轉換。 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()的強制類型轉換與parseInt()和parseFloat()方法的處理方式 相似,只是它轉換的是整個值,而不是部分值。 還記得嗎,parseInt()和parseFloat()方法只轉換第一個無效字符之前的 字符串,因此"4.5.6"將被轉換為"4.5"。 用Number()進行強制類型轉換,"4.5.6"將返回NaN,因為整個字符串值不 能轉換成數字。 如果字符串值能被完整地轉換,Number()將判斷是調用parseInt()方法還 是調用parseFloat()方法。 下表說明了對不同的值調用Number()方法會發(fā)生的情況: 用法結果 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 最后一種強制類型轉換方法 String()是最簡單的, 因為它可把任何值轉換成字符串。
要執(zhí)行這種強制類型轉換,只需要調用作為參數傳遞進來的值的 toString()方法,即把1 轉換成"1",把true 轉換成"true",把false 轉換成 "false",依此類推。 強制轉換成字符串和調用toString()方法的唯一不同之處在于,對null 或undefined 值強制類型轉換可以生成字符串而不引發(fā)錯誤: Js 代碼var s1=String(null);//"null"var oNull=null;var s2=oNull.toString();//won't work,causes an error3.利用js 變量弱類型 轉換 舉個小例子,一看,就會明白了。 Js 代碼script var str='012.345';var x=str-0;x=x*1;/script 上例 利用了js 的弱類型的特點,只進行了算術運算,實現(xiàn)了字符串到數字的類型轉 換,不過這個方法還是不推薦的。
標簽:
js
2012/07/21 at 09:41
有時候我們希望直接在模版上打印數組變量以供調試,打印的方式可以用php自帶的print_r或者是自己寫的調試函數,如debug().
如果直接這樣打印多維數組 {{$var|print_r}},在模版看到的結果會是遍歷后的所有的value,不會顯示完整的數組結構,正確的方法是在函數前加個@,意思是把變量作為整體去對待
{{$var|@print_r}}
標簽:
smarty
2012/07/14 at 15:41
php利用谷歌實現(xiàn)自動翻譯,以下是兩種實現(xiàn)的方式,php文檔用utf8就不會出現(xià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;
}
//截取相關信息
$return = "";
$star="style.backgroundColor='\#fff'\">";
$end="</span></span></div>";
$p = "#{$star}(.*){$end}#iU";//i表示忽略大小寫,U禁止貪婪匹配
if(preg_match_all($p,$wf,$rs))
{ print_r($rs);
return $rs[1][0];}
}
echo googleTran('去');
2012/06/27 at 11:42
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手機上網的一個瀏覽器; openwave|后面為各pc操作系統(tǒng)
{
echo "電腦訪問";
}
else
{
echo "手機訪問";
}
echo '<br/>'.$uAgent;
javascript中采用navigator.userAgent 來獲取,但非智能機似乎不支持js。
支持js的移動客戶端還可以用以下代碼簡單判斷是不是windows電腦訪問的
if(navigator.platform.indexOf('Win32')!=-1){
//go to pc
}else{
// go to 手機
}