Tài liệu Zend Framework: Tìm hiểu cơ bản về zend view: Zend Framework: Tìm hiểu cơ bản về zend view
Ở bài trước, chúng ta đã cùng tìm hiểu về quy trình hoạt động của zend
framework. Đồng thời cũng đã cấu hình ứng dụng nâng cao theo cơ chế
multi module trong zend framework (đa chức năng). Tiếp tục ở bài này, tôi
sẽ hướng dẫn các bạn tìm hiểu về phương pháp sử dụng zend view để thực
hiện hoàn chỉnh thao tác gởi dữ liệu đúng với chuẩn mực M-V-C trong Zend
Framework.
A- Tìm hiểu quy tắc hoạt động của Zend View
Trong controller của zend framework khi chúng ta khởi tạo một action
(hành động). Thì tương đương tại thư mục
views/scripts/tên_controller/hành_động.phtml.
Ví dụ:
Nếu là NewsController và addAction() thì chúng ta sẽ tạo view theo cấu trúc:
Views/scripts/news/add.phtml
Như vậy, Zend Framework sẽ tự động gọi views của action add khi người
dùng tham chiếu tới action add qua đường dẫn. Vậy những gì mà chúng ta
trình bày ở view add.phtml sẽ hiển thị cho người dùng thấy khi họ tham chiếu
tới action add.
Vậy ...
13 trang |
Chia sẻ: hunglv | Lượt xem: 1147 | Lượt tải: 0
Bạn đang xem nội dung tài liệu Zend Framework: Tìm hiểu cơ bản về zend view, để tải tài liệu về máy bạn click vào nút DOWNLOAD ở trên
Zend Framework: Tìm hiểu cơ bản về zend view
Ở bài trước, chúng ta đã cùng tìm hiểu về quy trình hoạt động của zend
framework. Đồng thời cũng đã cấu hình ứng dụng nâng cao theo cơ chế
multi module trong zend framework (đa chức năng). Tiếp tục ở bài này, tôi
sẽ hướng dẫn các bạn tìm hiểu về phương pháp sử dụng zend view để thực
hiện hoàn chỉnh thao tác gởi dữ liệu đúng với chuẩn mực M-V-C trong Zend
Framework.
A- Tìm hiểu quy tắc hoạt động của Zend View
Trong controller của zend framework khi chúng ta khởi tạo một action
(hành động). Thì tương đương tại thư mục
views/scripts/tên_controller/hành_động.phtml.
Ví dụ:
Nếu là NewsController và addAction() thì chúng ta sẽ tạo view theo cấu trúc:
Views/scripts/news/add.phtml
Như vậy, Zend Framework sẽ tự động gọi views của action add khi người
dùng tham chiếu tới action add qua đường dẫn. Vậy những gì mà chúng ta
trình bày ở view add.phtml sẽ hiển thị cho người dùng thấy khi họ tham chiếu
tới action add.
Vậy để truyền tham số mà chúng ta thao tác ở controller cho view như thế
nào ?.
Zend Framework cho phép người sử dụng truyền tham số thông qua phương
thức:
$this->view->tên_biến;
Và tại các file view có đuôi .phtml chúng ta chỉ cần sử dụng cú pháp: $this-
>tên_biến để lấy giá trị mà chúng ta đang truyền từ controller.
Ví dụ ta tạo controller tên: IndexController.php với nội dung:
1 <?php
2 class IndexController extends Zend_Controller_Action {
3 public function indexAction(){
4 $this->view->string= "hello Zend Framework – QHOnline.Info";
5 }
6
7 }
Tại thư mục views/scripts/index ta tạo file tên index.phtml với nội dung:
1 <?php
2 echo "".$this->string."";
3 ?>
Và kết quả sẽ ra là: Hello Zend Framework – QHOnline.Info
Như bạn thấy ta có thể truyền tham số và nhận tham số dễ dàng tại view với
quy tắc ở trên phải không nào.
Trường hợp truyền một mảng thì có cách truyền như sau:
01 <?php
02 class IndexController extends Zend_Controller_Action{
03 public function indexAction() {
04 $data= array(
05 'title' => 'Zend Framework',
06 'author'=> 'Kenny',
07 'date' => '20-11-2009',
08 'website'=> 'www.QHOnline.Info'
09 );
10 $this->view->info =$data;
11 }
12 }
Tại file view ta viết lại như sau:
1 <?php
2 foreach($this->info as $k => $v)
3 {
4 echo "$k: $v";
5 }
6 ?>
Chạy thử nghiệm:
Kết quả: dữ liệu của mảng sẽ được hiển thị như mong đợi.
Trong trường hợp, chúng ta không muốn action phải gọi view thì tại action
trong controller mà ta muốn, thêm vào phương thức sau:
$this->getHelper('viewRenderer')->setNoRender();
Khi sử dụng phương thức này thì tại action đó ta không cần phải tạo file
trong thư mục views. Vì nó bỏ qua việc render file view của action.
B- Nạp 1 file khác trong view như thế nào ?
Để thực hiện việc nạp 1 file khác vào view trong zend framework. Chúng ta
có thể gọi trong view thông qua phương thức:
echo $this->render("Tên_file.phtml");
Lưu ý là file của chúng ta phải lưu trong thư mục views/scripts/. Vì mặc định
trong zend view các file xử lý sẽ nằm tại thư mục views/scripts/
Ví dụ: Tạo action demo trong IndexController với nội dung như sau:
1 <?php
2 class IndexController extends Zend_Controller_Action{
3 function demoAction(){
4 $this->view->hello="Hello Zend Framework - QHOnline.Info";
5 }
6 }
Tạo tiếp file demo.phtml trong thư mục views/scripts/index/
1 <?php
2 echo "".$this->hello."";
3 echo $this->render("qhonline.phtml");
4 ?>
Tạo tiếp file qhonline.phtml trong thư mục: views/scripts
1 Khoa hoc PHP Online Version 2.0
Chạy thử nghiệm:
Kết quả: dữ liệu trả về với nội dung như mong đợi.
C- Thiết lập thông tin cơ bản trong zend view:
Zend view hỗ trợ người dùng những thư viện cấu hình cơ bản trong HTML
như , , ,… Như vậy để sử dụng được chúng ta cần thiết
lập chúng thông qua các controller và từ nó đổ tham số ra view.
a) Thiết lập chuẩn XHTML:
Cú pháp: doctype("Tham số")
Tham số chính là những chuẩn mà chúng ta mong muốn.
b) Thiết lập CSS:
Cú pháp: appendStylesheet(URL,Định dạng, Điều kiện)
Tương đương:
c) Thiết lập thẻ Title:
Cú pháp: headtitle("Tieu de")
Tương đương:
Tieu de
d) Thiết lập thẻ Meta:
Cú pháp: appendName("keyword","Zend Framework,");
Trường hợp thêm description ta có:
offsetSetName("1","description","Khoa hoc PHP Framework tai QHOnline")
Tham số đầu là vị trí, tham số sau là tên description và tham số thứ 3 là thông
tin.
e) Thiết lập thẻ script:
Cú pháp: appendFile(URL,"text/javascript")
Trường hợp nạp file js thứ 2
offsetSetFile("1","URL","text/javascript")
Ví dụ: Tạo testAction() trong controller index với nội dung:
01 function testAction(){
02 $baseurl=$this->_request->getbaseurl();
03 $this->view->doctype();
04 $this->view->headtitle("QHOnline.Info - Chapter 3: Zend Framework");
05
$this->view->headMeta()->appendName("keyword","Zend
Framework,Codeigniter,PHP Framework");
06
$this->view->headMeta()->offsetSetName("1","description","Khoa hoc
PHP Framework tai QHOnline");
07
$this->view->headLink()-
>appendStylesheet($baseurl."/public/css/test.css");
08
$this->view->headscript()-
>appendFile($baseurl."/public/js/test.js","text/javascript");
09
$this->view->headscript()-
>offsetSetFile("1",$baseurl."/public/js/test2.js","text/javascrip
10 }
Tạo tiếp file test.phtml tại thư mục: views/scripts/index với nội dung:
01 doctype() ?>
02
03
04 headTitle() ?>
05 headMeta() ?>
06 headLink() ?>
07 headScript() ?>
08
09
10 Hello Zend Framework – QHOnline.Info
11
12
Chạy thử nghiệm:
Kết quả: Title, meta, Css và javascript sẽ có tác dụng
Như bạn thấy đấy, ở trong đoạn code trên testAction() ta sử dụng phương
thức:
$baseurl=$this->_request->getbaseurl();
Đó là bởi vì, những gì mà chúng ta muốn tương tác được trong view như css,
javascript, hình ảnh hiển thị thì buộc chúng ta phải lấy được đường dẫn hiển
thị ứng dụng zend framework.
Và với $baseurl ở trên thực chất là chúng ta sẽ lấy được thư mục hiện hành
của ứng dụng là /zfexample. Và từ đó ta gọi tiếp các thông tin còn lại như
css, js và hình ảnh hiển thị.
Các file đính kèm theo tài liệu này:
- zend_framewor3_6651.pdf