国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

Heim php教程 php手冊 PHP做Web開發(fā)的MVC框架(Smarty使用說明 )

PHP做Web開發(fā)的MVC框架(Smarty使用說明 )

Jul 09, 2016 am 09:10 AM
mvc php smarty Webentwicklung Code Open Source rahmen Programmierung Programmiersprache Softwareentwicklung

<span style="font-size: 15px;"><span style="font-size: 18pt;">      PHP做Web開發(fā)的MVC框架(Smarty使用說明 )</span><br>一、Smarty簡明教程 </span>
<span style="font-size: 15px;">1.安裝演示 </span>
<span style="font-size: 15px;"> 下載最新版本的Smarty-3.1.12,然后解壓下載的文件。接下來演示Smarty自帶的demo例子。 </span>
<span style="font-size: 15px;">(1)下載地址:http://www.smarty.net/download </span>
<span style="font-size: 15px;">(2)在你的WEB服務器根目錄下建立新目錄,這里我在/var/www下創(chuàng)建yqting/目錄,然后將解壓之后的目錄中的demo/和libs/目錄復制到/var/www/yqting/目錄下。 <br>(3)這里要特別注意demo/目錄下cache/和template_c/兩個目錄,<strong><span style="color: #ff0000;">一定要設置它們 為可讀寫權限</span></strong>。 </span>
<span style="font-size: 15px;">  chmod 777 cache/ </span>
<span style="font-size: 15px;">  chmod 777 template_c/ </span>
<span style="font-size: 15px;">(4)啟動apache。在瀏覽器中輸入http://localhost/yqting/demo/index.php ,這樣一個簡單的Smarty demo就實現(xiàn)了。 </span>
<span style="font-size: 15px;">2.Smarty目錄結構 </span>
<span style="font-size: 15px;">(1)以/var/www/yqting目錄開始分析: </span>
<span style="font-size: 15px;">  yqting/ </span>
<span style="font-size: 15px;">    ├── demo </span>
<span style="font-size: 15px;">    │ ├── cache   緩沖文件存放目錄 </span>
<span style="font-size: 15px;">    │ ├── configs ?  配置文件目錄 </span>
<span style="font-size: 15px;">    │ ├── index.php </span>
<span style="font-size: 15px;">    │ ├── plugins ?  自定義的一些實用插件 </span>
<span style="font-size: 15px;">    │ ├── templates ?  模板目錄 </span>
<span style="font-size: 15px;">    │ └── templates_c   編譯后的文件存放目錄 </span>
<span style="font-size: 15px;">    └── libs</span>
<span style="font-size: 15px;">??     ├── debug.tpl   debug模板 </span>
<span style="font-size: 15px;">??     ├── plugins ?  自定義的一些實用插件</span>
<span style="font-size: 15px;">?    ? ├── SmartyBC.class.php    支持Smarty 2兼容 </span>
<span style="font-size: 15px;">    ?? ├── Smarty.class.php   Smarty類定義文件 </span>
<span style="font-size: 15px;">?    ? └── sysplugins ?  Smarty核心功能插件,不需要進行修改 </span>
<span style="font-size: 15px;">(2)添加自己定義的插件 </span>
<span style="font-size: 15px;">  上述目錄結構中,其實最核心的部分是libs/目錄,同時這部分也是不允許修改的。</span>
<span style="font-size: 15px;">  而要添加自己的插件,一種方法是將自己定義的插件放在libs/plugins/目錄下,另一種方式是 單獨創(chuàng)建一個自己plugins/目錄,同時還要創(chuàng)建cache/、configs/、templates/和templates _c/目錄,而且要保證cache/和templates_c/目錄的可讀寫權限。 </span>
<span style="font-size: 15px;">  不難發(fā)現(xiàn),其實上述例子中,demo/目錄就是一個包含了自己定義的插件的完整目錄。 我們可以參照demo/目錄來實現(xiàn)自己的程序。 </span>
<span style="font-size: 15px;">3.實現(xiàn)一個簡單的例子 </span>
<span style="font-size: 15px;">(1)在/var/www/yqting/下創(chuàng)建目錄weibo/,然后在weibo/目錄下創(chuàng)建cache/、 configs/、templates/和templates_c/目錄,修改cache/和templates_c/目錄的權限為可讀寫?! ?</span>
<span style="font-size: 15px;">(2)新建一個模板文件:index.tpl,將此文件放在/var/www/yqting/weibo/templates目錄下,代碼如下: </span>
<span style="font-size: 15px;">   </span>
<span style="font-size: 15px;">   </span>
<span style="font-size: 15px;">  <metahttp-equiv content="text/html;charset=gb2312"></metahttp-equiv></span>
<span style="font-size: 15px;">   <title>Smarty</title> </span>
<span style="font-size: 15px;">   </span>
<span style="font-size: 15px;">  </span>
<span style="font-size: 15px;">  username:{$Name}</span>
<span style="font-size: 15px;">   </span>
<span style="font-size: 15px;">  <br>  這段代碼很簡單,有什么不明白的繼續(xù)往下看,不要著急!每一個做顯示的.tpl文件都會對應一個處理業(yè)務邏輯的.php文件,下面介紹這個.php文件。</span>
<span style="font-size: 15px;">(3)新建index.php,將此文件放在/var/www/yqting/weibo/下,代碼如下: </span>
<span style="font-size: 15px;">  <?php <br>  </span><span style="font-size: 15px;">/*sample example */<br>  </span><span style="font-size: 15px;">require '../libs/Smarty.class.php'; <br>  </span><span style="font-size: 15px;">$smarty = new Smarty(); <br>  </span><span style="font-size: 15px;">$username = "Smarty"; <br>  $smarty->assign("Name",$username); <br>  </span><span style="font-size: 15px;">$smarty->display('index.tpl'); <br>  </span><span style="font-size: 15px;">?> <br>  其中require使用的路徑一定要正確,可以參照上面的目錄結構看一下!</span>
<span style="font-size: 15px;">(4)在Smarty3中,Smarty類的構造函數(shù)中已經指定了template_dir、compile_dir 、config_dir和cache_dir,不需要再次指定。     </span>
<span style="font-size: 15px;">(5) 在瀏覽器中輸入http://localhost/yqting/weibo/index.php,就可以看到輸出的信息username:Smarty 了。 </span>
<span style="font-size: 15px;">二、解釋smarty的程序 </span>
<span style="font-size: 15px;">  我們可以看到,smarty的程序部分實際就是符合php語言規(guī)范的一組代碼,我們依次來解釋一下:   </span>
<span style="font-size: 15px;">(1)/**/語句:</span>
<span style="font-size: 15px;">  包含的部分為程序篇頭注釋。主要的內容應該為對程序的作用,版權與作者及編寫時間 做一個簡單的介紹,這在smarty中不是必需的,但從程序的風格來講,這是一個好的風格。   </span>
<span style="font-size: 15px;">(2)include_once語句:</span>
<span style="font-size: 15px;">  它將安裝到網站的smarty文件包含到當前文件中,注意包含的路徑一定要寫正確。   </span>
<span style="font-size: 15px;">(3)$smarty = new Smarty(): </span>
<span style="font-size: 15px;">  這一句新建一個Smarty對象$smarty,簡單的一個對象的實例化。   </span>
<span style="font-size: 15px;">(4)$smarty->templates="": </span>
<span style="font-size: 15px;">  這一句指明$smarty對象使用tpl模板時的路徑,它是一個目錄,在沒有這一句時, Smarty默認的模板路徑為當前目錄的templates目錄,實際在寫程序時,我們要將這一 句寫明,這也是一種好的程序風格。   </span>
<span style="font-size: 15px;">(5)$smarty->templates_c="": </span>
<span style="font-size: 15px;">  這一句指明$smarty對象進行編譯時的目錄。在模板設計篇我們已經知道Smarty是 一種編譯型模板語言,而這個目錄,就是它編譯模板的目錄,要注意,如果站點位于linux 服務器上,請確保 teamplates_c里定義的這個目錄具有可寫可讀權限,默認情況下它的 編譯目錄是當前目錄下的templates_c,出于同樣的理由我們將其明確的寫出來。   </span>
<span style="font-size: 15px;">(6)<strong><span style="color: #ff0000; font-size: 16px;">分隔符 $smarty->left_delimiter與$smarty->right_delimiter: </span></strong></span>
<span style="font-size: 15px;">  指明在查找模板變量時的左右分割符。默認情況下為"{"與"}",但在實際中因為我們要 在模板中使用<script>,Script中的函數(shù)定義難免會使用{},雖然它有自己的解決辦法,但習慣上我們將它重新定義為"{#"與"#}"或是"<!--{"與"}-->"或其它標志符,注意,如果在這里定義了左右分割符后,在模板文件中相應的要使每一個變量使用與定義相同的符號, 例如在這里指定為"<{"與"}>",html模板中也要相應的將{$name}變成<{$name}>, 這樣程序才可以正確的找到模板變量。   </script></span>
<span style="font-size: 15px;">(7)$smarty->cache="./cache": </span>
<span style="font-size: 15px;">  告訴Smarty輸出的模板文件緩存的位置。上一篇我們知道Smarty最大的優(yōu)點在于它 可以緩存,這里就是設置緩存的目錄。默認情況下為當前目錄下的cache目錄,與 templates_c目錄相當,在linux系統(tǒng)中,我們要確保它的可讀可寫性。   </span>
<span style="font-size: 15px;">(8)$smarty->cache_lifetime = 60 * 60 * 24:   </span>
<span style="font-size: 15px;">  這里將以秒為單位進行計算緩存有效的時間。第一次緩存時間到期時當Smarty的 caching變量設置為true時緩存將被重建。當它的取值為-1時表示建立起的緩存從不過期, 為0時表示在程序每次執(zhí)行時緩 存總是被重新建立。上面的設置表示將cache_lifetime設置為一天。   </span>
<span style="font-size: 15px;">(9)$smarty->caching = 1:   </span>
<span style="font-size: 15px;">  這個屬性告訴Smarty是否要進行緩存以及緩存的方式。</span>
<span style="font-size: 15px;">  它可以取3個值,0: Smarty默認值,表示不對模板進行緩存;1:表示Smarty將使用當前定義的 cache_lifetime來決定是否結束cache;2:表示 Smarty將使用在cache被建立時使用 cache_lifetime這個值。習慣上使用true與false來表示是否進行緩存。   </span>
<span style="font-size: 15px;">(10)$smarty->assign("name", $username): </span>
<span style="font-size: 15px;">  該數(shù)的原型為assign(string varname, mixed var),varname為模板中使用的模板變量,var指出要將模板變量替換的變量名;其第二種原形為assign(mixed var),我們要在后面的例子詳細的講解這個成員函數(shù)的使用方法,assign是Smarty的核心函數(shù)之一, 所有對模板變量的替換都要使用它。   </span>
<span style="font-size: 15px;">(11)$smarty->display("index.tpl"):   </span>
<span style="font-size: 15px;">  該函數(shù)原形為display(string varname),作用為顯示一個模板。簡單的講,它將分析 處理過的模板顯示出來,這里的模板文件不用加路徑,只要使用一個文件名就可以了,它路 徑我們已 經在$smarty->templates(string path)中定義過了。   </span>
<span style="font-size: 15px;"><br>程序執(zhí)行完后我們可以打開當前目錄下的templates_c與cache目錄,就會發(fā)現(xiàn)在下 邊多出一些%%的目錄,這些目錄就是Smarty的編譯與緩存目錄,它由程序自動生成,不 要直接對這些生成的文件進行修改。   </span>
<span style="font-size: 15px;">以上我簡單的把Smarty程序中的一些常用的基本元素介紹了一下,在后邊的例子中你可以看到將它們將被多次的使用。</span>
<span style="font-size: 15px;">?</span>
Erkl?rung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Hei?e KI -Werkzeuge

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem v?llig kostenlosen KI-Gesichtstausch-Tool aus!

Hei?e Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Hei?e Themen

PHP-Tutorial
1502
276
VSCODE Settings.json Standort VSCODE Settings.json Standort Aug 01, 2025 am 06:12 AM

Die Datei "Settings.JSON" befindet sich auf dem Pfad auf Benutzerebene oder Arbeitsbereichsebene und wird verwendet, um die VSCODE-Einstellungen anzupassen. 1. Benutzer-Level-Pfad: Windows ist C: \ Benutzer \\ AppData \ Roaming \ Code \ User \ Settings.json, MacOS is /users//library/applicationsupport/code/user/settings.json, Linux is /home/.config/code/usser/setings.json; 2. Pfad auf Arbeitsbereichsebene: .VSCODE/Einstellungen im Projekt Root Directory

Aufbau unver?nderlicher Objekte in PHP mit Readonly -Eigenschaften Aufbau unver?nderlicher Objekte in PHP mit Readonly -Eigenschaften Jul 30, 2025 am 05:40 AM

ReadOmpropertiesinphp8.2canonlyBeSignedoncinstructororatDeklarationandCannotBemodifiedAfterward, durchsetzungsvermutbarkeitatheluagelevel.2.ToachedevimmiMmutability, WrapMutabletypesLikearrayObjecustomimmutablecollections

CSS -Beispiel für Dunkelmodus umschalten CSS -Beispiel für Dunkelmodus umschalten Jul 30, 2025 am 05:28 AM

Verwenden Sie zun?chst JavaScript, um die Einstellungen für Benutzersysteme und lokal gespeicherte Themeneinstellungen zu erhalten und das Seitenthema zu initialisieren. 1. Die HTML -Struktur enth?lt eine Schaltfl?che zum Ausl?sen von Themenwechsel. 2. CSS verwendet: root, um helle Themenvariablen zu definieren, .Dark-Mode-Klasse definiert dunkle Themenvariablen und wendet diese Variablen über var () an. 3.. JavaScript erkennt bevorzuge-farbige Scheme und liest LocalStorage, um das ursprüngliche Thema zu bestimmen. 4. Schalten Sie die Dark-Mode-Klasse im HTML-Element beim Klicken auf die Schaltfl?che und speichern Sie den aktuellen Status vor LocalStorage. 5. Alle Farb?nderungen werden mit einer übergangsanimation von 0,3 Sekunden begleitet, um den Benutzer zu verbessern

CSS -Dropdown -Menü Beispiel CSS -Dropdown -Menü Beispiel Jul 30, 2025 am 05:36 AM

Ja, ein gemeinsames CSS-Dropdown-Menü kann mit reinem HTML und CSS ohne JavaScript implementiert werden. 1. Verwenden Sie verschachtelte UL und Li, um eine Menüstruktur zu erstellen. 2. Verwenden Sie die: Hover Pseudo-Klasse, um die Anzeige und das Verstecken von Pulldown-Inhalten zu steuern. 3.. Setzen Sie Position: Relativ für Eltern -Li, und das Untermenü wird unter Verwendung von Position positioniert: absolut; 4. Das untergeordnete Standards ist angezeigt: Keine, die angezeigt wird: Block, wenn sie schwebend sind; 5. Multi-Level-Pulldown kann durch Verschachtelung, kombiniert mit dem übergang und Fade-In-Animationen erzielt und an mobile Terminals mit Medienabfragen angepasst werden. Die gesamte L?sung ist einfach und erfordert keine JavaScript -Unterstützung, was für gro?e geeignet ist

Java -Leistungsoptimierung und Profilerstellungstechniken Java -Leistungsoptimierung und Profilerstellungstechniken Jul 31, 2025 am 03:58 AM

Verwenden Sie Leistungsanalyse-Tools, um Engp?sse zu lokalisieren, VisualVM oder JProfiler in der Entwicklung und Testphase zu verwenden und Async-Profiler in der Produktionsumgebung Priorit?t zu geben. 2. Reduzieren Sie die Objekterstellung, verwenden Sie Objekte wieder, verwenden Sie StringBuilder, um String -Splei?en zu ersetzen und entsprechende GC -Strategien auszuw?hlen. 3.. Optimieren Sie die Auswahl der Sammlung, w?hlen Sie die Anfangskapazit?t gem?? der Szene aus; V. 5. Tune JVM-Parameter, festlegen, angemessene Haufengr??e und Müllsammler mit geringer Latenz einstellen und GC-Protokolle aktivieren; 6. Vermeiden Sie die Reflexion auf Codeebene, ersetzen Sie Wrapper -Klassen durch Grundtypen, Verz?gerungsinitialisierung und verwenden Sie endgültige und statische. 7. Kontinuierliche Leistungstest und überwachung, kombiniert mit JMH

Python iTertools -Kombinationen Beispiel Python iTertools -Kombinationen Beispiel Jul 31, 2025 am 09:53 AM

Itertools.combinations wird verwendet, um alle nicht repetitiven Kombinationen (irrelevant) zu generieren, die eine bestimmte Anzahl von Elementen aus dem iterablen Objekt ausw?hlen. Die Verwendung umfasst: 1. Auswahl 2 Elementkombinationen aus der Liste, wie z. 2. Nehmen Sie 3 Charakterkombinationen von Saiten wie "ABC" und "ABD", die für die Subsequence -Erzeugung geeignet sind; 3. Finden Sie die Kombinationen, in denen die Summe von zwei Zahlen dem Zielwert entspricht, z. B. 1 5 = 6, die Doppelschleifenlogik vereinfachen. Der Unterschied zwischen Kombinationen und Anordnung besteht darin, ob die Reihenfolge wichtig ist, Kombinationen betrachten AB und BA als gleich, w?hrend Permutationen als unterschiedlich angesehen werden.

Python für Data Engineering ETL Python für Data Engineering ETL Aug 02, 2025 am 08:48 AM

Python ist ein effizientes Instrument zur Implementierung von ETL -Prozessen. 1. Datenextraktion: Daten k?nnen aus Datenbanken, APIs, Dateien und anderen Quellen über Pandas, SQLalchemy, Anfragen und andere Bibliotheken extrahiert werden; 2. Datenumwandlung: Verwenden Sie Pandas für Reinigung, Typumwandlung, Assoziation, Aggregation und andere Vorg?nge, um die Datenqualit?t zu gew?hrleisten und die Leistung zu optimieren. A. Datenbelastung: Verwenden Sie Pandas 'TO_SQL -Methode oder Cloud -Plattform -SDK, um Daten an das Zielsystem zu schreiben, auf Schreibmethoden und Stapelverarbeitung zu achten. 4. Toolempfehlungen: Luftstrom, Dagster, Pr?fekten werden zur Prozessplanung und -verwaltung verwendet, um Protokollalarme und virtuelle Umgebungen zu kombinieren, um die Stabilit?t und Wartbarkeit zu verbessern.

Python PyTest Fixture Beispiel Python PyTest Fixture Beispiel Jul 31, 2025 am 09:35 AM

Das Fixture ist eine Funktion, mit der voreingestellte Umgebungen oder Daten für Tests bereitgestellt werden. 1. Verwenden Sie den Dekorateur für @PyTest.Fixure, um die Fixture zu definieren. 2. Inject Fixture in Parameterform in der Testfunktion; 3. Führen Sie ein Setup vor Ausbeute aus und rei?en Sie dann ab. 4. Steuerungsumfang durch Umfangsparameter wie Funktion, Modul usw.; 5. Legen Sie das gemeinsame Ger?t in conftest.

See all articles