摘要:一概念變量修飾器調節(jié)器可用于變量,自定義函數(shù)和字符串。請使用符號和修飾器名稱應用修飾器。變量修飾器由賦予的參數(shù)值決定其行為。與之相反將變量值轉成大寫字母所有字母,無參數(shù)。它與修飾器的效果剛好相反。它們會按復合的順序來作用于變量,從左到右。
一、概念
二、修飾器用法簡介 capitalize變量修飾器(調節(jié)器)可用于變量,自定義函數(shù)和字符串。 請使用‘|’符號和修飾器名稱應用修飾器。 變量修飾器由賦予的參數(shù)值決定其行為。 參數(shù)由‘:’符號分開。
使變量內容里的每個單詞的第一個字母大寫。 與PHP函數(shù)的 ucwords( )相似。
參數(shù)1:帶數(shù)字的單詞是否也頭字母大寫(Boolean,默認:false)
參數(shù)2:設置單詞內其他字母是否小寫,如"aA" 變成 "Aa"(Boolean,默認:false)
index.php: $smarty = new Smarty; $smarty->assign("articleTitle", "I want to buy a samsung s8"); $smarty->display("index.tpl"); index.tpl: {$articleTitle} {$articleTitle|capitalize} {$articleTitle|capitalize:true} OUTPUT: I want to buy a samsung s8 I Want To Buy A Samsung s8 I Want To Buy A Samsung S8
cat注:lower修飾器將變量值轉成小寫字母(所有字母),無參數(shù)。
upper與之相反將變量值轉成大寫字母(所有字母),無參數(shù)。
連接多個變量。
參數(shù)1:需要連接的變量(String)。
index.php: $smarty = new Smarty; $smarty->assign("articleTitle", "To be or not to be"); $smarty->display("index.tpl"); index.tpl: {$articleTitle} {$articleTitle|cat:"it is a question"} OUTPUT: To be or not to be To be or not to be it is a questioncount_characters
計算變量內容里有多少個字符。
參數(shù)1:計算總數(shù)時是否包括空格字符(Boolean,默認:false)。
index.php: $smarty = new Smarty; $smarty->assign("articleTitle", "Cold Wave Linked to Temperatures"); $smarty->display("index.tpl"); index.tpl: {$articleTitle} {$articleTitle|count_characters} {$articleTitle|count_characters:true} OUTPUT: Cold Wave Linked to Temperatures. 29 33count_paragraphs
計算變量內容有多少個段落。
index.php: $smarty = new Smarty; $smarty->assign("articleTitle", "I am a good guy! Yes I am!"); $smarty->display("index.tpl"); index.tpl: {$articleTitle} {$articleTitle|count_paragraphs} OUTPUT: I am a good guy! Yes I am! 2count_sentences
計算變量內容有多少個句子。 每個句子必須以點號、問號或者感嘆號結尾。
(./?/!)
index.php: $smarty = new Smarty; $smarty->assign("articleTitle", "I am a good guy.Yes I am! Are you sure? Yes!"); $smarty->display("index.tpl"); index.tpl: {$articleTitle} {$articleTitle|count_sentences} OUTPUT: I am a good guy.Yes I am! Are you sure? Yes! 4count_words
用于計算變量內容有多少個單詞。
index.php: $smarty = new Smarty; $smarty->assign("articleTitle", "I am a good guy.Yes I am! Are you sure? Yes!"); $smarty->display("index.tpl"); index.tpl: {$articleTitle} {$articleTitle|count_words} OUTPUT: I am a good guy.Yes I am! Are you sure? Yes! 12date_format
將日期和時間格式化成strftime( )的格式。 時間可以是unix的 時間戳, DateTime 對象, mysql時間戳,或者月日年格式的字符串,與PHP函數(shù)strtotime( )類似。并且可以對date_format的格式有完全的控制。 如果傳遞到date_format的時間為空, 而第二個參數(shù)傳遞了值,那么第二個參數(shù)將作為需要格式化的時間。
參數(shù)1:輸出時間的格式定義(String,默認:%b %e, %Y)
參數(shù)2:如果輸入為空,則作為默認時間(String,默認:n/a)
index.php: $smarty = new Smarty; $config["date"] = "%I:%M %p"; $config["time"] = "%H:%M:%S"; $smarty->assign("config", $config); $smarty->assign("yesterday", strtotime("-1 day")); $smarty->display("index.tpl"); index.tpl: {$smarty.now|date_format} {$smarty.now|date_format:"%D"} {$smarty.now|date_format:$config.date} {$yesterday|date_format} {$yesterday|date_format:"%A, %B %e, %Y"} {$yesterday|date_format:$config.time} OUTPUT: Jan 1, 2022 01/01/22 02:33 pm Dec 31, 2021 Monday, December 1, 2021 14:33:00
default附:date_format支持格式
W3C DATE_FORMAT( ) 函數(shù)
為變量設置默認值。 當變量是unset或者empty的字符串時,默認值將顯示。 必須要有一個參數(shù)。
參數(shù)1:當變量為空時輸出的值(String)
index.php: $smarty = new Smarty; $smarty->assign("articleTitle", "I am a good guy.Yes I am!"); $smarty->assign("email", ""); $smarty->display("index.tpl"); index.tpl: {$articleTitle|default:"no title"} {$myTitle|default:"no title"} {$email|default:"No email address available"} OUTPUT: I am a good guy.Yes I am! no title No email address availableescape
escape可用于將變量編碼或轉換成 html, url, 單引號, 十六進制, 十六進制實體, javascript 和 email地址。 默認是:html。
參數(shù)1:這是escape轉換后的格式(String,默認:html,可取值:html, htmlall, url, urlpathinfo, 單引號, 十六進制, 十六進制實體, javascript, email地址)
參數(shù)2:傳遞給htmlentities( )的字符集類型(String,默認:UTF-8,可取值:ISO-8859-1, UTF-8, 和其他 htmlentities()支持的字符集)
參數(shù)3:兩次轉換實體,& 到 & (僅在 html 和 htmlall 使用)(Boolean,默認:true)
index.php: $smarty = new Smarty; $smarty->assign("articleTitle", ""Stiff Opposition Expected to Casketless Funeral Plan"" ); $smarty->assign("EmailAddress","smarty@example.com"); $smarty->display("index.tpl"); index.tpl & OUTPUT: {$articleTitle} "Stiff Opposition Expected to Casketless Funeral Plan" {$articleTitle|escape} 'Stiff Opposition Expected to Casketless Funeral Plan' {$articleTitle|escape:"html"} 'Stiff Opposition Expected to Casketless Funeral Plan' {$articleTitle|escape:"htmlall"} 'Stiff Opposition Expected to Casketless Funeral Plan' click here click here {$articleTitle|escape:"quotes"} "Stiff Opposition Expected to Casketless Funeral Plan" {$EmailAddress|escape:"hexentity"} {$EmailAddress|escape:"mail"} {* this converts to email to text *} bob..snip..et {"mail@example.com"|escape:"mail"} smarty [AT] example [DOT] com
indent注:unescape可以解碼entity, html 和 htmlall等的編碼。 它與escape 修飾器的效果剛好相反。
縮進每一行的字符串,默認是縮進4個空格。 可選的參數(shù)可以設置縮進的空格數(shù)量。 可選的第二個參數(shù)設置縮進使用的字符,如用 "t" 來代替空格縮進。
參數(shù)1:設置縮進多少空格(Integer,默認:4)
參數(shù)2:設置用什么字符來進行縮進(String,默認:一個空格)
index.php: $smarty = new Smarty; $smarty->assign("articleTitle", "NJ judge to rule on nude beach. Sun or rain expected today, dark tonight. Statistics show that teen pregnancy drops off significantly after 25.""); $smarty->display("index.tpl"); index.tpl: {$articleTitle} {$articleTitle|indent} {$articleTitle|indent:10} {$articleTitle|indent:1:" "} OUTPUT: NJ judge to rule on nude beach. Sun or rain expected today, dark tonight. Statistics show that teen pregnancy drops off significantly after 25. NJ judge to rule on nude beach. Sun or rain expected today, dark tonight. Statistics show that teen pregnancy drops off significantly after 25. NJ judge to rule on nude beach. Sun or rain expected today, dark tonight. Statistics show that teen pregnancy drops off significantly after 25. NJ judge to rule on nude beach. Sun or rain expected today, dark tonight. Statistics show that teen pregnancy drops off significantly after 25.nl2br
將變量值中的"n"回車全部轉換成HTML的
。 等同于PHP的 nl2br()函數(shù)。
index.php: $smarty = new Smarty; $smarty->assign("articleTitle", "I am a good guy. Yes I am!") $smarty->display("index.tpl"); index.tpl: {$articleTitle|nl2br} OUTPUT: I am a good guy.regex_replace
Yes I am!
用正則表達式搜索和替換變量值。 使用PHP的 preg_replace()函數(shù)進行。
參數(shù)1:正則表達式(String,默認:n/a)
參數(shù)2:替換的字符(String,默認:n/a)
index.php: $smarty = new Smarty; $smarty->assign("articleTitle", "I am a good guy. Yes I am!") $smarty->display("index.tpl"); index.tpl: {$articleTitle} {$articleTitle|regex_replace:"/[ ]/":" "} OUTPUT: I am a good guy. Yes I am! I am a good guy. Yes I am!
spacify注:replace修飾器用法相似,對變量進行簡單的搜索和替換。 等同于PHP函數(shù)的 str_replace()。
spacify會在變量的字符串中插入空格。 你可以設置插入的是空格或者別的字符。
參數(shù)1:插入字符間的字符(String,默認:一個空格)
index.php: $smarty = new Smarty; $smarty->assign("articleTitle", "Something Went Wrong in Jet Crash, Experts Say") $smarty->display("index.tpl"); index.tpl: {$articleTitle} {$articleTitle|spacify} {$articleTitle|spacify:”^"} OUTPUT: Something Went Wrong in Jet Crash, Experts Say. S o m e t h i n g W .... snip .... s h , E x p e r t s S a y . S^o^m^e^t^h^i^n^g^.... snip .... ^e^r^t^s^ ^S^a^y^.string_format
格式化字符串,如浮點數(shù)等。 使用 sprintf()的PHP函數(shù)來進行。
參數(shù)1:指定哪種格式 (sprintf)(String,默認:n/a)
index.php: $smarty = new Smarty; $smarty->assign("number", 3.1415926); $smarty->display("index.tpl"); index.tpl: {$number} {$number|string_format:"%.2f"} {$number|string_format:"%d"} OUTPUT: 3.1415926 3.14 3strip
轉換連續(xù)空格,回車和tab到單個空格或是指定字符串。
PS.如果希望轉換模板文字內的空格,使用內置的 {strip} 函數(shù)。
index.php: $smarty = new Smarty; $smarty->assign("articleTitle", “I am so good that they all like me"); $smarty->display("index.tpl"); index.tpl: {$articleTitle} {$articleTitle|strip} {$articleTitle|strip:" "} OUTPUT: I am so good that they all like me I am so good that they all like me I am so good that they all like metruncate
截取字符串到指定長度,默認長度是80.
參數(shù)1:截取的長度(Integer,默認:80)
參數(shù)2:截取后替代顯示的字符,該字符長度會被計算到截取長度內(String,默認:…)
參數(shù)3:默認truncate會嘗試按單詞進行截取。 如果你希望按字符截取(單詞可能會被截斷),需要設置第三個參數(shù)TRUE。(Boolean,默認:false)
index.php: $smarty = new Smarty; $smarty->assign("articleTitle", "Two Sisters Reunite after Eighteen Years at Checkout Counter"); $smarty->display("index.tpl"); index.tpl: {$articleTitle} {$articleTitle|truncate} {$articleTitle|truncate:30} {$articleTitle|truncate:30:""} {$articleTitle|truncate:30:"---"} {$articleTitle|truncate:30:"":true} {$articleTitle|truncate:30:"...":true} {$articleTitle|truncate:30:"..":true:true} OUTPUT: Two Sisters Reunite after Eighteen Years at Checkout Counter Two Sisters Reunite after Eighteen Years at Checkout Counter Two Sisters Reunite after... Two Sisters Reunite after Two Sisters Reunite after--- Two Sisters Reunite after Eigh Two Sisters Reunite after E... Two Sisters Re..ckout Counterwordwrap
限制一行字符的長度(自動換行),效果與PHP函數(shù)wordwrap()一樣。
參數(shù)1:限定一行的長度(Integer,默認:80)
參數(shù)2:換行符號,可自定義換行字符(String,默認:n)
參數(shù)3:設置按單詞換行(FALSE),或者按字符換行(TRUE),默認情況下,是根據(jù)單詞來換行的,也就是按英文語法的自動換行。 如果你希望按照字符來換行(邊界的單詞將拆開),那么可以設置 可選的第三個參數(shù)為TRUE
index.php: $smarty = new Smarty; $smarty->assign("articleTitle’,"Blind woman gets new kidney from dad she hasn"t seen in years"); $smarty->display("index.tpl"); index.tpl: $articleTitle} {$articleTitle|wordwrap:30} {$articleTitle|wordwrap:20} {$articleTitle|wordwrap:30:"三、復合修飾器
"} {$articleTitle|wordwrap:26:" ":true} OUTPUT: Blind woman gets new kidney from dad she hasn"t seen in years Blind woman gets new kidney from dad she hasn"t seen in years Blind woman gets new kidney from dad she hasn"t seen in years Blind woman gets new kidney
from dad she hasn"t seen in
years Blind woman gets new kidn ey from dad she hasn"t se en in years
可以聯(lián)合使用多個修飾器。 它們會按復合的順序來作用于變量,從左到右。 它們必須以“|” (豎線)進行分隔。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/26105.html
摘要:還有安全特性,可以令模板源碼有強制的約束。并且業(yè)務邏輯和顯示邏輯分離,是的一個設計理念。是一個模板引擎,在應用程序中,當作層視圖層的組件來使用。不一定保證良好的程序設計或者達成顯示分離的目的,這還得需要開發(fā)者和模板設計師的努力。 一、 Smarty的由來 Smarty的主要設計理念是:干凈的分離顯示邏輯和程序代碼,在PHP為后端情況下,Smarty模板應用在前端,增強PHP的前后端交互...
摘要:本篇,我們就在自己的項目中使用來進行依賴管理。輸入,即可安裝依賴到目錄中,并且自動生成和。安裝依賴,提示從提示可以看出,讀取的是中的依賴,而不是最新的。訪問,正常工作。源碼分享書簽從零開始打造自己的框架中文網(wǎng)中文文檔 Composer Composer 是 PHP5.3以上 的一個依賴管理工具。它允許你申明項目所依賴的代碼庫,它會在你的項目中為你安裝他們。Composer 不是一個包管...
摘要:體現(xiàn)了業(yè)務與顯示的分離,盡量分離。就負責判斷條件,并取出數(shù)據(jù)來。顯示的工作盡量靠前頁面緩存緩存,重要概念。減輕了數(shù)據(jù)庫的壓力。控制局部不緩存在標簽中控制,該標簽不緩存。模板調用特殊方法使用對象注冊的方式來解決。文件命名函數(shù)名定 模板 數(shù)據(jù)與表現(xiàn)層的標簽分離 smarty是PHP 與 HTML代碼的分離 小型模板類 $smarty 的工作流程: 把需要顯示的全局變量,賦值塞到對象內部的...
摘要:最近工作中用到模板引擎,整理了一些用到的模板函數(shù)。模板中獲取服務端的值參數(shù)名模板中獲取服務端的值參數(shù)名模板中獲取服務端的值可以獲取或的值。 最近工作中用到 Smarty 模板引擎,整理了一些用到的模板函數(shù)。 假設 smarty 的定界符為 {}。 模板中獲取服務端 $_GET 的值: {$smarty.get.參數(shù)名} 模板中獲取服務端 $_POST 的值: {$smarty.post...
閱讀 2857·2021-10-21 09:38
閱讀 2759·2021-10-11 10:59
閱讀 3041·2021-09-27 13:36
閱讀 1664·2021-08-23 09:43
閱讀 797·2019-08-29 14:14
閱讀 3037·2019-08-29 12:13
閱讀 3207·2019-08-29 12:13
閱讀 316·2019-08-26 12:24