Smarty-phpのテンプレートエンジン
・Smartyとは
PHPで利用できるテンプレートエンジンです。Smartyを使うことで画面デザインとプログラム部分を分けて開発することが容易となる。
【環境条件】
OS:win10
XAMPP v3.2.1
Eclipse(ルナ)
【ダウンロード】
Smartyのダウンロードは
http://www.smarty.net/から行います。
data:image/s3,"s3://crabby-images/d1cee/d1cee40cd247732a11ce1f269cc45f080db83649" alt=""
から3・1・30をクリックする
data:image/s3,"s3://crabby-images/6e735/6e735fcd9faeb49413584f48e842a19fa3705af6" alt=""
の上の(zip)をクリックするとダウンロードが始まる
data:image/s3,"s3://crabby-images/c5ceb/c5ceb7896ba4f039e006c0c3b06279279cfc2b29" alt=""
ドキメントは上のようにする。
【インストール】
ダウンロードされたsmarty-3.1.30.zipをc:\xamppに展開する
data:image/s3,"s3://crabby-images/395b6/395b663b614878b361bf371e643b378c5424b0be" alt=""
data:image/s3,"s3://crabby-images/00aff/00affa5b068834f86c8bb4f3d83f1d2f4aad8386" alt=""
c:\xampp\smarty-3.1.30フォルダが作成されたら、smarty-3.1.30フォルダをsmartyに変更する
※php.iniファイルの変更
;;;;;;;;;;;;;;;;;;;;;;;;;
; Paths and Directories ;
;;;;;;;;;;;;;;;;;;;;;;;;;
; UNIX: "/path1:/path2"
;include_path = ".:/php/includes"
;
; Windows: "\path1;\path2"
include_path=".;C:/xampp/php/PEAR;C:/xampp/php/PHPMailer;C:/xampp/smarty/libs;"
赤字をinclude_pathに追加する。
【Eclipseの設定】
・EclipseでSmartyのテンプレートファイル拡張子tplをhtmlファイルとして関連付ける
data:image/s3,"s3://crabby-images/49808/49808c1cd89213db868c7a6ae87d23344c2ce89f" alt=""
メニューバーから「ウィンドウ」→「設定」→「一般」→「コンテンツタイプ」→「テキスト」→「HTML」まで行くと下の「ファイルの関連付け」ボックスにHTMLに関連付ける拡張子の一覧が表示されるので、「追加」から「.tql」を関連付けてあげる。
・新規の作成
data:image/s3,"s3://crabby-images/a04ff/a04ff166032180490a9ac031d0ff9146babce115" alt=""
1)プロジェクSmartyを作成する
data:image/s3,"s3://crabby-images/432be/432bee44973c90e5ab210a7a969d4eb24eebdc7b" alt=""
2)必用なフォルダを作成する
data:image/s3,"s3://crabby-images/b9a1d/b9a1dd12b230531d8ea36c5c8c1c8dc56ca5ea97" alt=""
templates テンプレートファイル設置
templates_c コンパイルしたテンプレート設置
configs コンフィグファイル設置
cache キャッシュ
3)phpファイルを作成する
data:image/s3,"s3://crabby-images/e1e2b/e1e2bd7676936df3c1915da19c0a0de1d6f9fdc8" alt=""
【index.php】
<?
require_once "Smarty.class.php";
/*
$path = getcwd();
$smarty->template_dir = "{$path}/templates";
$smarty->compile_dir = "{$path}/templates_c";
$smarty->config_dir = "{$path}/config";
$smarty->cache_dir = "{$path}/cacha";
*/
$smarty = new Smarty;
$smarty->assign('name', '桃太郎');
$smarty->display('index.tpl');
?>
以上
ただし、c\:xampp\htdocs\のルート上にある時は/*~*/のディレクトリ指定は省略出来る
4)templatesフォルダーにテンプレートファイルindex.tplを作成
data:image/s3,"s3://crabby-images/320db/320db16af1b83a29edaca1df23f713f6c7fa70cc" alt=""
【index.tpl】
{* index.tpl *}←tplのコメント
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>smartyのテスト</title>
</head>
<body>
ようこそ、{$name}さん<br />
HelloWorld!
</body>
</html>
5)フォルダやファイルの確認!
data:image/s3,"s3://crabby-images/29981/29981ab118730f0010dc3d82b10ac5b22697e06a" alt=""
6)実行
この様に表示されればOK
data:image/s3,"s3://crabby-images/57312/5731255a58e0f8a1c737f9823a98e1cd51a4b32e" alt=""
※コメント投稿者のブログIDはブログ作成者のみに通知されます