Ở bài trước, chúng ta đã có dịp nói về cách cài đặt và tìm hiểu kiến trúc bên trong của CakePHP. Trong bài, chúng tôi tiếp tục hưỡng dẫn các bạn sử dụng và làm quen với các quy ước cơ bản trong CakePHP. Qua đó nắm bắt tổng quan đồng thời vận dụng CakePHP một cách linh hoạt nhất có thể.
13 trang |
Chia sẻ: vietpd | Lượt xem: 1639 | Lượt tải: 0
Bạn đang xem nội dung tài liệu Cake PHP Framework: Một số quy ước cơ bản, để tải tài liệu về máy bạn click vào nút DOWNLOAD ở trên
CakePHP Framework: Một số quy ước cơ bản
Ở bài trước, chúng ta đã có dịp nói về cách cài đặt và tìm hiểu kiến trúc bên
trong của CakePHP. Trong bài, chúng tôi tiếp tục hưỡng dẫn các bạn sử dụng
và làm quen với các quy ước cơ bản trong CakePHP. Qua đó nắm bắt tổng
quan đồng thời vận dụng CakePHP một cách linh hoạt nhất có thể.
Cách đặt tên file, tên lớp
- Tên file sử dụng chữ thường, dùng dấu “_” để phân cách các từ
- Tên lớp dùng CamelCased (viết hoa chữ cái đầu tiên của từ)
Ví dụ : ta có tên lớp là MyClass-> file class tương ứng :my_class.php
Dưới đây là các ví dụ về cách đặt tên file cho mỗi dạng lớp khác nhau mà bạn
thường sử dụng trong ứng dụng CakePHP :
Các qui ước về Model và CSDL
- Tên các lớp model được đặt ở dạng số ít và việc viết hoa thường tuân theo
CamelCased
Ví dụ: Person, BigPerson và ReallyBigPerson.
- CakePHP không hỗ trợ khóa chính gồm nhiều cột. Nếu bạn muốn thao tác
trực tiếp kết nối (join) các bảng, hãy truy vấn trực tiếp hoặc thêm một khóa
chính thay cho khóa nhiều cột.
Ví dụ:
1 CREATE TABLE posts_tags (
2 id INT(10) NOT NULL AUTO_INCREMENT,
3 post_id INT(10) NOT NULL,
4 tag_id INT(10) NOT NULL,
5 PRIMARY KEY(id));
- Lẽ ra trong table post_tags, bình thường thì 2 cột post_id và tag_id ta có
thể cho nó làm khóa chính nhưng CakePHP không chấp nhận điều này.
- Tên bảng tương ứng với các model của CakePHP ở dạng số nhiều và sử
dụng gạch dưới (_) tên bảng tương ứng với các model ở trên là people,
big_people, và really_big_people.
- Tuy nhiên, bạn vẫn có thể đặt tên bảng khác đi và cho CakePHP biết điều
này thông qua biến $useTable trong model (các bài viết tiếp theo sẽ có ví
dụ).
- Bạn có thể dùng thư viện Inflector có sẵn trong CakePHP để kiểm tra dạng
số ít/số nhiều của các từ.
- Các khóa ngoại trong các quan hệ hasMany, belongsTo, hasOne có tên
mặc định là số ít của tên bảng kèm theo _id ở cuối cùng.
Ví dụ với quan hệ NewsCategory có nhiều News, bảng news sẽ có khóa
ngoại đến bảng news_categories là news_category_id.
- Các bảng liên kết được sử dụng trong quan hệ
hasAnhBelongsToMany(viết tắt là HABTM – quan hệ nhiều nhiều) được
đặt tên bằng cách kết nối các tên model theo thứ tự abc, vì vậy tên đúng sẽ là
apples_zebras chứ không phải là zebras_apples.
- Do đó, ta phải thêm một khóa khác có tên là id
- Khóa chính mặc định trong CakePHP là cột id, kiểu int, tự tăng. Tuy nhiên,
bạn cũng có thể định nghĩa lại khóa chính cho bảng thông qua biến
$primaryKey trong model.
- Thay cho việc sử dụng kiểu int, auto-increment làm khóa chính, bạn có thể
sự dụngchar(36)hoặc binary(36), khi đó CakePHP sẽ tự động tạo ra UUIDs
để làm khóa khi ta thêm mới một record. UUID là một chuỗi gồm 32 byte,
tương ứng với 36 ký tự.
Ví dụ :550e8400-e29b-41d4-a716-446655440000
Qui ước về Controller :
- Tên lớp của controller đặt theo dạng số nhiều,
- Tuân theo CamelCased và cuối tên phải có chữ “Controller”.
Ví dụ: ta có Controller tênProductsthì có class Controller như sau :
1 <?php
2 Class ProductsController extends AppController{
3 //Mã lệnh ở đây
4 }
5 ?>
- Khi một phương thức trong Controller được đặt tên bắt đầu với với dấu
“_”ở phía trước, bạn sẽ không thể truy xuất nó từ bên ngoài mà chỉ có thể
truy xuất trong controller đó (cái này gọi là private).
Ví dụ:
01 <?php
02 Class ProductsControllers extends AppController{
03
function
index(){
04 //Mã lệnh ở đây
05 }
06
07 function _get_product(){
08 //Mã lệnh ở đây
09 }
10
11 function viewProduct(){
12 $this->_get_product();
13 }
14 }
15 ?>
Kết quả hiển thị như sau:
index() : public function
_get_product() : private function
Mô tả hoạt động :
- function index() :run
- function _get_product() :not run
- function _get_product() :run
Ví dụ :
Ta có controller NewsController với 2 function:
- View_all()
- View_detail()
Thì ta phải có 2 file tương ứng :
- View_all.ctp
- View_detail.ctp
Đặt trong thư mục app/view/news
- Mặc định, nếu trong controller NewsController có methodview(), khi gọi
actionviewtrên trình duyệt ( thì Controller sẽ tìm
file view.ctp trong app/views/news/view.ctp
- Tuy nhiên, bạn có thể gọi một file view khác không phải là view.ctp bằng
lệnh
1 <?php
2 $this->render('ten_view');
3 ><
Ví dụ về mặc định :
1 <?php
2 Class NewsController extends AppController{
3
4 function view(){
5 …
6 }
7 }
8 ?>
-Truy cập :>load file :view.ctptrong thư mục
app/views/news/
Ví dụ về load 1 file view khác :
1 <?php
2 Class NewsController extends AppController{
3
4 function view(){
5 ….
6 $this->render(“view_demo”);
7 }
8 }
9 ?>
- Truy cập :> load file :view_demo.ctp trong thư
mụcapp/views/news/
Tổng kết : viết demo đơn giản với CakePHP
- Viết dứng dụng đơn giản với đường link
:
- Từ link trên, ta cần có :
- Model : trong ví dụ này không xử lý dữ liệu nên không cần viết
- View : file view.ctp để hiển thị kết quả : Ban dang chon tro choi thu 12
- Controller :Relax với action Playgame nhận tham số 12
Cách thực hiện :
- Vào thư mục app/controllers/ tạo relaxs_controller.php với nội dung :
01 <?php
02 class RelaxsController extends AppController {
03
04 function index(){
05 }
06
07 function playgame($id=null){
08 $info = array(
09 "title_page" => "CakePHP demo by qhonline.info",
10 "id" => $id,
11 );
12 $this->set("data",$info);
13 }
14 }
Ghi chú : Hàm $this->set(“data”,$info) gán mảng giá trị $info vào biến $data
để hiển thị bên View tương ứng
- Vào thư mục app/views/ tạo thư mục relaxs ứng với Controllers relaxs
trên
- Trong thư mục relaxs mới tạo , ta tạo file playgame.ctp với nội dung :
01
02
03
04
05 <?php
06 echo $this->Html->charset();
07 echo $data['title_page']; /* Tiêu đề của trang web */
08 ?>
09
10
11
12 <?php
13 echo "Ban dang choi tro choi thu ".$data['id'];
14 ?>
15
16
-Kiểm tra kết quả :
Title không hiển thị kết quả như mong muốn do CakePHP có 2 chế độ :
- Dùng template có sẳn của nó
- Template của mình
Trong ví dụ này , mình dùng template mặc định nên phần title là do CakePHP
quyết định