1.在控制器MainController里面寫一個方法,調用Nation表中的數據。
public function zhuyemian() { $n = D("Nation");//造一個Nation對象 $attr = $n->select();//查詢所有數據,返回的是一個二維數組。 $this->assign("n",$attr);//將二維數組注冊到模板里面顯示. $this->show();//調用模板顯示 }
2.新建一個顯示的模板文件zhuyemian.html
<body> <table width="100%" border="1" cellpadding="0" cellspacing="0"> <tr> <td>代號</td> <td>名稱</td> <td>操作</td> </tr> <foreach name="n" item="v"><!--用foreach內置標簽標簽循環出表格信息,v代表小數組。--> <tr> <td>{$v.code}</td><!--注意這里是{$v.code},而不是{$v[0]},因為查到的數據是二維關聯數組--> <td>{$v.name}</td> <td><a href="__CONTROLLER__/xiugai/code/{$v.code}">修改</a><!--因為是在同一個控制器里面,可以直接用__CONTROLLER__獲取到該控制器的路徑,后面寫上xiugai方法,再在后面寫要傳的值的名稱,最后寫上值。路徑不能寫死,要寫成動態的,模板里面的所有路徑都盡量不要寫死,都要用常量信息寫。--> <a href="__CONTROLLER__/shanchu/code/{$v.code}" onclick="return confirm('確定刪除嗎?')">刪除</a></td><!--指向刪除方法並且傳一個code值,code值也是{$v.code}--> </tr> </foreach> </table> </body>
3.顯示頁面
4.做修改顯示頁面xiugai.html
<body> <form action="__ACTION__" method="post"><!--action指向當前控制器,只要是找鏈接、路徑都要用常量信息寫,不要寫死--> <input type="hidden" name="Code" value="{$nation.code}" /> <div>名稱:<input type="text" name="Name" value="{$nation.name}" /></div> <div><input type="submit" value="修改" /></div> </form> </body>
5.在控制器MainController里面寫修改方法
public function xiugai($code="")//xiugai方法里面要實現2個邏輯,1是顯示頁面,2是修改信息。 { $n = D("Nation"); if(empty($_POST))//判斷POST數組是否為空,如果是空的,就顯示頁面。 { $nation = $n->find($code);//find只找1條數據,並且是一維數組。 $this->assign("nation",$nation); $this->show(); } else//POST數組不為空就執行修改邏輯 { //修改 $n->create();//自動收集表單,create收集表單比較智能,有別的表單會自動忽略掉,比如注冊賬號的時候會讓用戶輸入2個密碼,這樣就需要把2個密碼框中的一個設置成列名,另外一個隨便設置一個非列名,這個不是列名的密碼框會自動忽略掉。所以不需要提交的表單不用列名就可以。 $r = $n->save();//save方法是修改的方法 if($r) { $this->success("修改成功","zhuyemian");//修改成功后,提示“修改成功”並且跳轉到zhuyemian.html } else { $this->error("修改失敗");//修改失敗提示“修改失敗。” } } }
6.點擊修改,跳轉到修改頁面,並且傳對應的code值。
修改成功后,點擊“修改”。
7.在控制器MainController里面寫刪除方法
public function shanchu($code)//刪除方法也需要一個code { $n=D("Nation");//造對象 $r = $n->delete($code);//調用刪除方法,直接把主鍵值作為參數放在()里面就可以。 if($r) { $url = U("zhuyemian");//用U方法造一個路徑 $this->success("刪除成功",$url);//把造的路徑放在要跳轉的頁面里面,注意不能直接也頁面,會出錯。 } else { $this->error("刪除失敗"); } }
thinkphp3.2.3使用手冊
8.模板
(1)變量輸出
變量輸出和smarty模板時一樣的,都是{$name}。
(2)系統變量的輸出
{$Think.server.script_name} // 輸出$_SERVER['SCRIPT_NAME']變量
{$Think.session.user_id} // 輸出$_SESSION['user_id']變量
{$Think.get.pageNumber} // 輸出$_GET['pageNumber']變量
{$Think.cookie.name} // 輸出$_COOKIE['name']變量
{$Think.const.MODULE_NAME}//輸出常量
{$Think.config.db_charset}//輸出配置參數
{$Think.lang.page_error}//取語言
(3)使用函數(用|調用)
{$data.name|md5}//$data.name調用md5
表示date函數傳入兩個參數,每個參數用逗號分割,這里第一個參數是{$create_time|date="y-m-d",###}//
y-m-d
,第二個參數是前面要輸出的create_time
變量,因為該變量是第二個參數,因此需要用###標識變量位置,編譯后的結果是:<?php echo (date("y-m-d",$create_time)); ?>
(4)默認值輸出
{$Think.get.name|default="名稱為空"}//默認值輸出使用的是default,實際上也是一個函數。
(5)使用運算符
對模板輸出使用運算符,也包括“+”“ ” “*” “/”和“%”。
(6)模板繼承
模板繼承是一項更加靈活的模板布局方式,模板繼承不同於模板布局,甚至來說,應該在模板布局的上層。模板繼承其實並不難理解,就好比類的繼承一樣,模板也可以定義一個基礎模板(或者是布局),並且其中定義相關的區塊(block),然后繼承(extend)該基礎模板的子模板中就可以對基礎模板中定義的區塊進行重載。
示例:a.做一個父類的方法
public function fu() { $this->show(); }
b.做父類的顯示頁面
<title>無標題文檔</title> <block name="tou"></block><!--做頭部的區域,子類文件可以在這里繼承頭部--> </head> <body> <div style="width:100%; height:200px; </div> <block name="neirong"></block><!--做body的區域,子類文件可以在這里繼承body--> <div style="width:100%; height:100px; </div> </body>
c.做子模板的方法
public function zi() { $this->show(); }
d.做子類的顯示頁面
<extend name="fu" /><!--extend代表繼承的意思,name里面是要繼承的模板的名字--> <block name="tou"> <title>測試子模板</title> </block> <block name="neirong"> <div style="width:100%; height:300px; </div> </block>
這樣顯示出來的頁面就是子頁面,但是頭部和尾部都繼承了父頁面。
(7)包含文件
在當前模版文件中包含其他的模版文件使用include標簽,標簽用法:
<include file="Public/header" /> // 包含頭部模版header
<include file="Public/menu" /> // 包含菜單模版menu
<include file="Blue/Public/menu" /> // 包含blue主題下面的menu模版
(8)比較標簽
他們的用法基本是一致的,區別在於判斷的條件不同,並且所有的比較標簽都可以和else標簽一起使用。
例如:<eq name="name" value="value">value</eq>表示name變量的值等於value就輸出
(9)import標簽
傳統方式的導入外部JS和CSS文件的方法是直接在模板文件使用:
<script type='text/javascript' src='/Public/Js/Util/Array.js'>
<link rel="stylesheet" type="text/css" href="/App/Tpl/default/Public/css/style.css" />
系統提供了專門的標簽來簡化上面的導入:
第一個是import標簽 ,導入方式采用類似ThinkPHP的import函數的命名空間方式,例如:
<import type='js' file="Js.Util.Array" />
Type屬性默認是js, 所以type='js'可以不寫。
還可以支持多個文件批量導入,例如:
<import file="Js.Util.Array,Js.Util.Date" />
9.SESSION和Cookie
SESSION在thinkphp里面不需要加session_start()開啟了,在配置文件里面有一項配置是true默認開啟的。
SESSION存儲數據
session(array('name'=>'session_id','expire'=>3600));
Session初始化設置方法無需手動調用,在Think\App類的初始化工作結束后會自動調用,通常項目只需要配置SESSION_OPTIONS
參數即可,SESSION_OPTIONS
參數的設置是一個數組,支持的索引名和前面的session初始化參數相同。
默認情況下,初始化之后系統會自動啟動session,如果不希望系統自動啟動session的話,可以設置SESSION_AUTO_START
為false,設置方式:
'SESSION_AUTO_START' =>false
Session賦值比較簡單,直接使用:
session('name','value'); //設置session
Session取值使用:
$value = session('name');
// 獲取所有的session 3.2.2版本新增
$value = session();
刪除某個session的值使用:
session('name',null); // 刪除name
要判斷一個session值是否已經設置,可以使用
// 判斷名稱為name的session值是否已經設置
session('?name');
Cookie設置
cookie('name','value'); //設置cookie
cookie('name','value',3600); // 指定cookie保存時間
還可以支持參數傳入的方式完成復雜的cookie賦值,下面是對cookie的值設置3600秒有效期,並且加上cookie前綴think_
cookie('name','value',array('expire'=>3600,'prefix'=>'think_'))
獲取cookie很簡單,無論是怎么設置的cookie,只需要使用:
$value = cookie('name');
如果沒有設置cookie前綴的話 相當於
value = $_COOKIE['name'];
刪除某個cookie的值,使用:
cookie('name',null);
要刪除所有的Cookie值,可以使用:
cookie(null); // 清空當前設定前綴的所有cookie值
cookie(null,'think_'); // 清空指定前綴的所有cookie值