首頁 >後端開發 >php教程 >史上最全的使用THinkPHP心得和技巧,比手冊還好用

史上最全的使用THinkPHP心得和技巧,比手冊還好用

WBOY
WBOY原創
2016-07-25 09:03:201317瀏覽
史上最全的使用THinkPHP心得和技巧,比手冊還好用,走過路過千萬不要錯過。
使用THinkPHP的心得與技巧總結(一)http://www.jb100.net/html/content-28-475-1.html
使用THinkPHP的心得與技巧總結(二)http://www.jb100.net/html/content-28-477-1.html
使用THinkPHP的心得與技巧總結(三)http://www.jb100.net/html/content-28-479-1.html
使用THinkPHP的心得與技巧總結(四)http://www.jb100.net/html/content-28-248-1.html

這是史上最全的THINKPHP使用技巧總結,比手排還好用,各種用法都有詳細說明,特別適合新手,走過路過千萬不要錯過啊!

約定:
1.所有類別庫檔案必須使用.class.php作為檔案後綴,並且類別名稱和檔案名稱保持一致
2.控制器的類別名稱以Action為後綴
3.模型的類別名稱以Model為後綴,類別名稱第一個字母須大寫
4.資料庫表名全部採用小寫,

如:
資料表名: 前綴_表名
模型類別名稱: 表名Model 註:這裡的表名第一個字母要大寫
建立物件: D('表名') 註:這裡的表名第一個字母要大寫

定義控制器類別
class IndexAction extends Action{
public function show(){
echo '這是新的 show 操作';
}
}
然後在瀏覽器裡面輸入
http://localhost/myApp/index.php/Index/show/

定義模型類別:
class 表名Model extends Model{
[//手動定義欄位[可選]
protected $fields = array(
'id',
'username',
'email',
'age',
'_pk'=>'id', //主鍵
'_autoInc'=>true //是否自增
)
]
}

記錄的修改:
$User = D("User") // 實例化 User 物件
$User->find(1) // 找出 id 為 1 的記錄
$User->name = 'ThinkPHP' // 把查找到的記錄的名稱欄位修改為 ThinkPHP
$User->save() // 儲存修改的資料
更新特定欄位的值
$User->setField('name','TopThink','id=1')
同 樣可以支援對欄位的操作
$User->setField('score','(score+1)','id=1')

新建記錄,方法1:
$User = new UserModel() //實例化 User 物件
$User->字 段名 = 欄位值 //給欄位賦值
$User->add() //新增記錄
新建記錄,方法2:
$data['字段名'] = 字段值; //給字段賦值
$User = D('User'); //實例化 User 物件
$User->add($data); //$insertId,Add 方法的回傳值就是最新插入的主鍵值,可以直接取得。
新增多筆記錄:
$User = new UserModel()
$data[0]['name'] = 'ThinkPHP'
$data[0]['email'] = 'sjolzy@chen.com'
$data[1]['name'] = '流年'
$data[1]['email'] = 'chen@sjolzy.cn'
$User>addAll($data)

刪除記錄
$User->find(2)
$User->delete() // 刪除查找到的記錄
$User->delete('5,6') // 刪除主鍵為 5、6 的資料
$User->deleteAll() // 刪除查詢出來的所有資料

記錄查詢

$User->getDbFields() //取得目前資料欄位
$User->findAll(); //找所有記錄
$User->findAll('1,3,8') //查詢主鍵為1,3,8的記錄集
$User->count() // 取得記錄數
$User->max('score') // 取得使用者的最大積分
$User->min('score','score>0') // 取得積分大於 0 的使用者的最小積分
$User->avg('欄位名稱') // 取得所有記錄的欄位值的平均值
$User->sum('欄位名稱 ') // 統計欄位值
$User->getN(2,'score>80','score desc') // 傳回符合條件的第 2 筆記錄
$User->getN(2,'score>80','score desc') //還可以取得最後第二筆記錄
$User->first('score>80','score desc') //如果要查詢第一筆記錄,還可以使用
$User->last('score>80','score desc') // 取得最後一筆記錄
$User->top(5,'','score desc') // 取得最高積分的前 5 筆記錄
$User->getBy('name','liu21st') //跟據欄位的欄位值來查詢記錄

$Model = new Model() // 實例化一個 model 物件 沒有對應任何資料表
$Model->query("select * from think_user where status=1")

$objrs = $Model->query("select * from think_user where status=1") //自訂查詢
$Model->execute("update think_user set name='thinkPHP' where status=1") //用於更新和寫入資料的 sql 操作,傳回影響的記錄數

$User->startTrans() // 啟動事務
$User->commit() // 提交事務
$User->rollback() // 事務回滾

模板:

$this->assign('name',$value); //在 Action 類別裡面使用 assign 方法對模板變數賦值,無論何種變數型別都統一使用 assign 賦值

$this->display() // 輸出模版檔

批量賦值
$array['name'] = 'thinkphp'
$array['email'] = 'chen@sjolzy.cn'
$array['phone'] = '12335678'
$this->assign($array)

$this->display() // 呼叫 User 模組的 read 操作模版
$this->display('edit') // 呼叫 User 模組的 edit 操作模版
$this->display('Member:read') // 呼叫 Member 模組的 read 操作模版
$this->display('Xp@User:edit') // 呼叫 Xp 主題的 User 模組的 edit 操作模版
$this->display('../Member/read.html') // 直接指定模版檔案的全名

模板標籤:

{ } 或 {// 註解內容 } //範本註解
{$user['name']} //輸出陣列變數
{$user:name} //輸出物件的屬性

為了方便模板定義,無論輸出的模板變數是數組還是對象,都可以用下列統一方式輸出:
{$user.name}
如果是多維數組或多 層物件屬性的輸出,請使用下面的定義方式:
{$user['sub']['name']}
{$user:sub:name}

使用函數:
格式:{$varname|function1|function2=arg1,arg2,### }
說明:
{ 和 $ 符號之間不能有空格 ,後面參數的空格就沒有問題
###表示模板變數本身的參數位置
。 。 。 。 。 。 。 。 。 。 。 。 。

由於文字太多,這裡只是部分心得和技巧,更多精彩的分享網址如下:

使用THinkPHP的心得與技巧總結(一)http://www.jb100.net/html/content-28-475-1.html
使用THinkPHP的心得與技巧總結(二)http://www.jb100.net/html/content-28-477-1.html
使用THinkPHP的心得與技巧總結(三)http://www.jb100.net/html/content-28-479-1.html
使用THinkPHP的心得與技巧總結(四)http://www.jb100.net/html/content-28-248-1.html



陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn