Hướng dẫn viết module cho nukeviet 3.x Để dễ thao tác các bạn hãy làm giống mình phần code (số dòng) Trong khuôn khổ bài viết này mình sẽ trình bày với các bạn cấu trúc cơ bản, công dụng cũng như chức năng của từng file trong thư mục module và cách viết một module chi tiết từ đơn giản tới phức tạp. -- Cấu trúc một module, chức năng các file, các file, floder bắt buộc phải có. -- Cách viết một module đơn giản chỉ chứa file PHP. -- Mở rộng kết hợp file PHP riêng ngoài các file bắt buộc phải có. -- Làm việc với file ngôn ngữ lang. -- Sử dụng xtemplate. -- Mở rộng thêm các file thông tin module, RSS -- Sử dụng javscript và ajax cho module (phần AJAX các bạn xem tại viewtopic.php?f=117&t=15403). -- Sử dụng lớp (class) đã được xây dựng sẵn. -- Tích hợp thêm các phần mở rộng Trước khi vào phần hướng dẫn mình xin trình bày một số quy ước. Các file PHP được bắt đầu với phần thông tin về tác giả, bản quyền, ngày viết, email tác giả.. VÍ dụ như: /** * @Project NUKEVIET-MUSIC * @Author Phan Tan Dung () * @copyright 2011 * @createdate 26/01/2011 09:17 AM */
Tương tự cho các file js /* * * @Project NUKEVIET-MUSIC * @Author Phan Tan Dung () * @copyright 2011 * @createdate 26/01/2011 09:17 AM */
Tên module tốt nhất các bạn chỉ đặt tên bằng chữ cái không chứa các kí tự đặc biệt.
Bây giờ ta vào phần chi tiết. ---- CẤU TRÚC CƠ BẢN CỦA MỘT MODULE Bao gồm các file và thư mục sau: - admin.functions.php - version.php - funcs - funcs/main.php - admin - admin/main.php - functions.php Với nhiêu đó là ta đã có một module đơn giản (không có CSDL) có thể hoạt động rồi. Như vậy muốn viết một module đầu tiên ta tạo một thư mục có tên là tên của module trong thư mục modules. Sau đó lần lượt tạo các thư mục, file như trên vào thư mục vừa tạo. Mình sẽ ví dụ đây là module quanlihs.
1
Chức năng của các file như sau: -- file version.php: file này có chức năng khai báo tiêu đề module, các funcs có block, tác giả module, thông tin phiên bản, cấu trúc thư mục trong thư mục uploads. -- File admin.functions.php: File này thường chứa các function, hằng dùng trong admin -- File function.php: File này thường chứa các function, hằng dùng cho ngoài site -- admin/main.php: File này sẽ thể hiện nội dung của module phần admin -- funcs/main.php: FIle này sẽ thể hiện nội dung (trang chính) của module bên ngoài site. Thứ tự khởi động một module như sau: Khi module được chạy thì tùy theo admin hay ngoài site mà file admin.functions.php hay file function.php được chạy trước sau đó là các file trong thư mục admin hay funcs được chạy tiếp theo mặc định sẽ là file main.php. Ta thường thấy url trang web nukeviet (chưa bật rewrite) có dạng http://yourdomain/index.php? lang=vi&nv= ... =listenone
Trong đó lang chính là ngôn ngữ của site, nv là module đang chạy, op chính là funcs đang chạy (ở đây là listenone). Giá trị op này chính là tên của funsc trong thư mục funsc hay admin. Nếu trên url mà khuyết phần op= có nghĩa funcs main.php đang được chạy. Cấu trúc url như trên là cấu trúc cơ bản. Giá trị op ta có thể thay đổi ví dụ như . Ta sẽ tìm hiểu sau. Bây giờ chúng ta bắt đầu viết một module đơn giản (không có CSDL) để xuất ra dòng chữ "XIN CHÀO CÁC BẠN" bên trong admin và ngoài site. Đầu tiên tạo một thư mục (là tên module) trong thư mục modules rồi thêm vào đó các file và thư mục sau: - admin.functions.php - version.php - funcs - funcs/main.php - admin - admin/main.php - functions.php file version.php có nội dung: /** * @Project NUKEVIET-MUSIC * @Author Phan Tan Dung () * @copyright 2011 * @createdate 05/12/2010 09:47 */ if ( ! defined( 'NV_ADMIN' ) or ! defined( 'NV_MAINFILE' )) die( 'Stop!!!' ); $module_version = array( "name" => "QuanLyHocSinh", // Tieu de module "modfuncs" => "main" , "is_sysmod" => 0, "virtual" => 1,
Dòng này: if ( ! defined( 'NV_ADMIN' ) or ! defined( 'NV_MAINFILE' )) die( 'Stop!!!' ); các bạn để nguyên ở mọi module -"modfuncs" => "main": Tên các funcs trong thư mục funcs có block khi hoạt động bên ngoài site. Đối với các funcs không có block ví dụ như để xử lý AJAX, gửi email (popup) thì không cần khai báo. Các funcs được phân cách nhau bởi dấu "," ví dụ: "modfuncs" => "main, funcs1, funcs2, funcs3" ,
-"is_sysmod" => 0, : Có phảo module hệ thông hay không 0: không 1: có. -"virtual" => 1: CHo phép ảo hóa module không 0: không 1: có -date,author, version: thông tin ngày , tác giả, phiên bản module. -uploads_dir: Khai báo cấu trúc thư mục trong thư mục uploads. Với khai báo như trên thì khi kích hoạt module hệ thông sẽ tạo một thư mục có tên là tên của module trong thư mục upload (biến $module_name được hiểu là tên module) file admin.functions.php có nội dung như sau: /**
* @Project NUKEVIET-MUSIC * @Author Phan Tan Dung () * @Copyright 2011 * @createdate 26/01/2011 10:08 AM */ if ( ! defined( 'NV_ADMIN' ) or ! defined( 'NV_MAINFILE' ) or ! defined( 'NV_IS_MODADMIN' ) ) die( 'Stop!!!' ); $allow_func = array('main'); define( 'NV_IS_MUSIC_ADMIN', true ); ?>
- $allow_func = array('main'); : biến $allow_func là một mảng một chiều chứa các funcs rong thư mục admin cho phép chạy. Ở ví dụ này chỉ cho một funcs là main.php. Các funcs không được khai báo trong biến này khi chạy sẽ báo lỗi "Bạn không có quyền truy cập chức năng này." - define( 'NV_IS_QUANLY_ADMIN', true ); Dòng này sẽ khởi tạo một hằng dùng cho module. Các funcs như main.php sẽ kiểm tra giá trị hằng này nếu đúng sẽ chạy ngược lại sẽ báo lỗi "Stop!!!". file function.php các bạn thêm như sau:
/** * @Project NUKEVIET-MUSIC * @Author Phan Tan Dung () * @copyright 2011 * @createdate 26/01/2011 10:10 AM */ if (!defined('NV_SYSTEM')) die('Stop!!!'); define('NV_IS_MOD_QUANLY', true); ?>
3
Với module đơn giản như ví dụ này thì file này chỉ có chức năng tạo một hằng để dùng bên ngoài site thôi. Tạo file main.php trong thư mục admin với nội dung như sau: /** * @Project NUKEVIET-MUSIC * @Phan Tan Dung () * @Copyright (C) 2011 * @Createdate 26-01-2011 14:43 */ if ( ! defined( 'NV_IS_QUANLY_ADMIN' ) ) die( 'Stop!!!' ); $page_title = "Trang chính"; $contents = "Xin chào các bạn"; include (NV_ROOTDIR . "/includes/header.php"); echo nv_admin_theme($contents); include (NV_ROOTDIR . "/includes/footer.php"); ?>
- Biến $page_title là tiêu đề của funcs hiện tại. - Tất cả nội dung sẽ được lưu vào một biến $contents sau đó sẽ được xuất ra sau khi gọi file header.php. Phần : include (NV_ROOTDIR . "/includes/header.php"); echo nv_admin_theme($contents); include (NV_ROOTDIR . "/includes/footer.php");
Các bạn giữ nguyên mọi module (trong admin) Tương tự tạo file main.php lưu vào thư mục funcs với nội dung như sau:
/** * @Project NUKEVIET-MUSIC * @Author Phan Tan Dung * @Copyright (C) 2011 * @Createdate 26/01/2011 10:26 AM */ if ( ! defined( 'NV_IS_MOD_QUANLY' ) ) die( 'Stop!!!' ); $page_title = $module_info['custom_title']; $key_words = $module_info['keywords']; $contents = "Xin chào các bạn"; include ( NV_ROOTDIR . "/includes/header.php" ); echo nv_site_theme( $contents ); include ( NV_ROOTDIR . "/includes/footer.php" ); ?>
4
OK như vậy ta đã tạo xong một module đơn giản để xuất ra dong chữ "Xin chào các bạn" bên trong admin lẫn ngoài site. Bây giờ các bạn vào phần thiết lập module mới kích hoạt modlue vừa tạo rồi vào phần quản lí của module và noài site bạn sẽ thấy kết quả. ------------Với module Đơn giản này ta có thể sử dụng để inframe trang khác hoặc liên kết sang trang khác khi ấn vào menu. Ví dụ thay file main.php bằng: /** * @Project NUKEVIET-MUSIC * @Author Phan Tan Dung * @Copyright (C) 2011 * @Createdate 26/01/2011 10:26 AM */
if ( ! defined( 'NV_IS_MOD_QUANLY' ) ) die( 'Stop!!!' ); $page_title = $module_info['custom_title']; $key_words = $module_info['keywords']; $contents = '1029px; height: 693px"> Your browser does not support inline frames or is currently configured not to display inline frames. </iframe> '; include ( NV_ROOTDIR . "/includes/header.php" ); echo nv_site_theme( $contents ); include ( NV_ROOTDIR . "/includes/footer.php" ); ?>
Ta có module inframe của trang 24h Hay thay file main.php bằng :
Ta có module khi vào thì sẽ chuyển sang trang o. Hay các bạn có thể dùng vào nhiều việc khác.
5
Tiếp theo chúng ta sẽ thêm file action.php làm nhiệm vụ thao tác với CSDL khi cài đặt cũng như xóa module. Bây giờ ta thêm một table trong CSDL để quản lí học sinh trong lớp (STT, họ tên, ngày sinh, địa chỉ). Tạo file action.php đặt cùng thư mục với file functions.php với nội dung như sau: /** * @Project NUKEVIET-MUSIC * @Author Phan Tan Dung () * @copyright 2011 * @createdate 26/01/2011 10:10 AM */ if( !defined('NV_IS_FILE_MODULES') ) die('Stop!!!'); $sql_drop_module = array(); $sql_drop_module[] = "DROP TABLE IF EXISTS `" . $db_config['prefix'] . "_" . $lang . "_" . $module_data . "`"; $sql_create_module = $sql_drop_module; $sql_create_module[] = "CREATE TABLE `" . $db_config['prefix'] . "_" . $lang . "_" . $module_data . "` ( `id` mediumint(8) unsigned NOT NULL AUTO_INCREMENT, `stt` INT( 255 ) unsigned NOT NULL,
`hoten` varchar(255) NOT NULL, `ngaysinh` INT( 11 ) NOT NULL DEFAULT '0', `diachi` varchar(255) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM"; ?>
Các bạn vào phần quản lí module cài lại module sẽ thấy trong CSDL có thêm một table. Mình giải thích nội dung file trên: $sql_drop_module[], $sql_create_module[] để chỉ việc xóa, tạo mới module. Biến $db_config['prefix'] là tiếp đầu tố của table, $lang là ngôn ngữ của site, $module_data thông thường được hiểu như tên của module. Nội dung bên trong dấu ngoặc kép là lệnh thao tác với CSDL không nhất thiết phải là xóa, thêm mà có thể chỉnh sửa, xóa trường, chèn dữ liệu... Biến $sql_create_module[] dạng ARRAY nên có thể thêm nhiều lệnh thao thác csdl (tạo nhiều bảng).
6
Ta đã tạo CSDL thành công bây giờ cần phải viết code để làm việc với nó. Bây giờ phần quản lí module ta cần có thêm một submenu để thêm học sinh. Mở file admin.functions.php lên sửa lại như sau: /** * @Project NUKEVIET-MUSIC * @Author Phan Tan Dung () * @Copyright 2011 * @createdate 26/01/2011 10:08 AM */ if ( ! defined( 'NV_ADMIN' ) or ! defined( 'NV_MAINFILE' ) or ! defined( 'NV_IS_MODADMIN' ) ) die( 'Stop!!!' );
Ta thấy bây giờ có thêm $submenu['add'] có nghĩa là ta đã khai báo một submenu trong admin, biến $allow_func thêm mới 'add' có nghĩa ta đã chấp nhận thêm một funcs mới có tên add (add.php). Bây giờ các bạn vào phần quản lí module sẽ thấy có thêm submenu "Thêm học sinh" nhưng khi ấn vào sẽ hiện : "Lỗi truy cập 404 Lỗi 404: Trang web mà bạn đã cố gắng truy cập không tồn tại trên máy chủ của website." có nghĩa là chưa có file add.php. Ta thêm file add.php vào thư mục admin với nội dung như sau: /** * @Project NUKEVIET-MUSIC * @Phan Tan Dung () * @Copyright (C) 2011 * @Createdate 26-01-2011 14:43 */ if ( ! defined( 'NV_IS_QUANLY_ADMIN' ) ) die( 'Stop!!!' ); $page_title = "Thêm học sinh"; $my_head = ""js/popcalendar/popcalendar.js\"></script>\n"; $my_head .= ""js/shadowbox/shadowbox.js\"></script>\n"; $my_head .= "NV_BASE_SITEURL . "js/shadowbox/shadowbox.css\" />\n"; $my_head .= "<script type=\"text/javascript\">\n"; $my_head .= "Shadowbox.init({\n"; $my_head .= "});\n"; $my_head .= "</script>\n";
Với đoạn code trên ta có một funcs với chức năng thêm học sinh. Mình giải thích như sau: Đoạn này là phần sử dụng biến $my_head để gọi java và CSS. Tạm thời phần này cho qua đến phần sử dụng java chúng ta sẽ quay lại. Ở đây ta đã gọi ra shadowbox.css, shadowbox.js, popcalendar.js để làm nhiệm vụ hiển thị lịch. $my_head = ""js/popcalendar/popcalendar.js\"></script>\n";
Đoạn này dùng để lấy dữ liệu khi submit form và được lưu dưới dạng mảng (array). Các cách lấy dữ liệu các bạn có thể tham khảo tại bài hướng dẫn viết module đội code viết. if ( ($nv_Request->get_int( 'add', 'post', 0 ) == 1) ) { if ( $data['hoten'] == "" ) { $error = "Bạn chưa nhập tên học sinh";
Đoạn này thực hiện việc lấy giá trị stt lớn nhất, tăng giá trị này lên một và ghi dữ liệu vào CSDL. if( $error ) { $contents .= "<div class=\"quote\" style=\"width: 780px;\">\n <blockquote class=\"error\"> <span>".$error."</span> </blockquote> </div>\n <div class=\"clear\"> </div>"; }
Đoạn này là xuất ra lỗi (nếu có) CÒn phần cuối cùng là phần nội dung hiển thị (form). Ta vừa thực hiện xong việc thêm học sinh.
Bây giờ ta cần hiển thị danh sách các học sinh. Mở file main.php trong thư mục admin và chỉnh lại như sau: /** * @Project NUKEVIET-MUSIC * @Phan Tan Dung ()
11
* @Copyright (C) 2011 * @Createdate 26-01-2011 14:43 */ if ( ! defined( 'NV_IS_QUANLY_ADMIN' ) ) die( 'Stop!!!' ); $page_title = "Trang chính"; $contents = " <table class=\"tab1\"> <thead> <tr> <td> STT </td> <td> Họ và tên </td> <td> Ngày sinh </td> <td> Địa chỉ
Đoạn code trên thực hiện việc đọc thông tin từ CSDL và xuất ra ngoài site qua vòng lặp while. Riêng phần ngày sinh thì dùng hàm date để định dạng theo ngày/tháng/năm. Cơ bản xong phần admin. Bây giờ ta đi tiếp bên ngoài site để thể hiện danh sách các học sinh. Chỉnh lại file main.php trong thư mục funcs như sau: 12
/** * @Project NUKEVIET-MUSIC * @Author Phan Tan Dung * @Copyright (C) 2011 * @Createdate 26/01/2011 10:26 AM */ if ( ! defined( 'NV_IS_MOD_QUANLY' ) ) die( 'Stop!!!' ); $page_title = $module_info['custom_title']; $key_words = $module_info['keywords']; $contents = ''; $contents = " <table class=\"tab1\"> <thead> <tr> <td> STT </td> <td> Họ và tên </td> <td>
include ( NV_ROOTDIR . "/includes/header.php" ); echo nv_site_theme( $contents ); include ( NV_ROOTDIR . "/includes/footer.php" ); ?>
13
Đoạn code trên cũng tương tự như file main.php trong admin, cũng đọc dữ liệu và xuất ra.
Ta vừa hoàn thành xong một module đơn giản để thực hiện việc quản lí học sinh trong lớp. Qua hai file main.php ta lại thấy trùng nhau ở doạn này: $sql = "SELECT * FROM `" . NV_PREFIXLANG . "_" . $module_data . "` ORDER BY stt ASC"; $resuilt = $db->sql_query( $sql ); while ( $row = $db->sql_fetchrow( $resuilt ) )
Để tối ưu hóa hơn, bây giờ ta sẽ gộp hai đoạn đó thành một. Như vậy tiết kiệm được một chút tài nguyên (với những module lớn thì tiết kiệm đáng kể). Giải pháp để thực hiện là viết class riêng hoặc dùng function riêng. Mình sẽ giới thiệu cách dùng function đặt trong một file mở rộng ngoài những file bắt buộc. Ta thêm vào một file global.functions.php đặt ngang hàng với file action.php với nội dung như sau: /** * @Project NUKEVIET-MUSIC * @Author Phan Tan Dung () * @copyright 2011 * @createdate 26/01/2011 09:17 AM */
if ( ! defined( 'NV_MAINFILE' ) ) die( 'Stop!!!' ); function getALLstudent( ) { global $module_data, $db; $data = array() ; $result = $db->sql_query( "SELECT `stt`, `hoten`, `ngaysinh`, `diachi` FROM " . NV_PREFIXLANG . "_" . $module_data . " ORDER BY stt ASC" ); while ( list ( $stt, $hoten, $ngaysinh, $diachi ) = $db>sql_fetchrow($result) ) { $data[] = array ( "stt" => $stt, "hoten" => $hoten, "ngaysinh" => date ( "d/m/Y", $ngaysinh ), "diachi" => $diachi ); } return $data ; } ?>
Đoạn code trên là một function getALLstudent( ). global $module_data, $db là để gọi vào các biến bên ngoài. Ví dụ này gọi vào biến $module_data có giá trị như tên của module, biến $db là class thao tác với CSDL. Tất cả thông tin học sinh sẽ được lưu dưới dạng mảng hai chiều và được trả về ở lệnh return.
14
Để sử dụng file trên thì ta mở file functions.php và admin.functions.php lên thêm vào dòng cuối cùng (phía trên ?>):
Như vậy kể từ bây giờ file global.functions.php trực tiếp tham gia vào admin lẫn bên ngoài site, thiếu file này hoặc viết sai đều xuất hiện trang trăng. Tiếp tục sửa lại hai file main.php cho phù hợp như sau: Trong admin: /** * @Project NUKEVIET-MUSIC * @Phan Tan Dung () * @Copyright (C) 2011 * @Createdate 26-01-2011 14:43 */ if ( ! defined( 'NV_IS_QUANLY_ADMIN' ) ) die( 'Stop!!!' ); $page_title = "Trang chính"; $contents = " <table class=\"tab1\"> <thead> <tr> <td> STT </td> <td> Họ và tên </td> <td> Ngày sinh </td> <td>
Ta vừa hoàn thành xong phần "Sử dụng file php riêng" Ngoài cấu trúc cở bản (các file, floder) bắt buộc các bạn có thể mở rộng tùy ý, có thể thêm bất kì floder, file nào tùy ý. Tiếp theo ta sẽ làm việc với file lang (ngôn ngữ) để có thể mở rộng ra nhiều ngôn ngữ khác ngoài tiếng Việt. Tạo thư mục language ngang hàng với thư mục admin. Tạo file admin_vi.php và file vi.php nằm trong thư mục vừa tạo. Đây là fie ngôn ngữ tiếng việt, dùng trong admin thì bắt đầu bằng admin_ còn ngoài site thì tên file là tên của kí tự ngôn ngữ. Các kí tự ngôn ngữ các bạn tham khảo thêm ở module news. Nội dung file admin_vi.php như sau: /** * @Project NUKEVIET-MUSIC * @Author Phan Tan Dung () * @Language Vietnamese * @Createdate Jan 26, 2011 11:30:02 AM */
$lang_module['birthdate'] = "Ngày sinh"; $lang_module['address'] = "Địa chỉ"; $lang_module['add_student'] = "Thêm học sinh"; $lang_module['add_student_err_name'] = "Bạn chưa nhập tên học sinh"; $lang_module['add_student_err_bd'] = "Bạn chưa nhập ngày sinh của học sinh"; $lang_module['add_student_err_ar'] = "Bạn chưa nhập địa chỉ"; $lang_module['add_student_err_save'] = "Không thể lưu dữ liệu được"; $lang_module['add_student_info'] = "Thông tin học sinh mới"; $lang_module['save'] = "Lưu"; ?>
Ta thấy có hia phần $lang_translator và $lang_module trong đó $lang_module là phần ngôn ngữ dùng cho module còn $lang_translator là thong tin tác giả, bản quyền, ngày dịch, ngôn ngữ dịch..... Để sử dụng file ngôn ngữ thì sau khi tạo đến bước trên ta cần mở tất cả các file trong thư mục admin lên, thay tất cả các dòng chữ bằng $lang_module tương ứng. Sau khi thay ta được hai file main.php và add.php như sau:
include ( NV_ROOTDIR . "/includes/header.php" ); echo nv_site_theme( $contents ); include ( NV_ROOTDIR . "/includes/footer.php" ); ?>
CHúng ta vừa hoàn thành xong phần làm việc với file lang bây giờ ta tiếp tục đến với phần sử dụng xtemplate. xtemplate thực chất là một lớp (class) được xây dựng sẵn và luôn được tích hợp trong nukeviet. Để sử dụng nó ta cần quan tâm đến 3 phần như sau. -- Gọi file tpl -- lệnh $xtpl->assign
-- lệnh $xtpl->parse -- lẹnh $xtpl->text( 'main' ) Để gọi ra một file tpl ta dùng như sau:
Ta thấy có hai phần phân cách nhau bởi dấu phảy. phần trước chính là tên của file tpl là phần sau là đường dẫn đến file tpl đó. Các giá trị hằng, biến NV_ROOTDIR, $module_info['template'], $module_file các bạn tham khảo trong file mainfile.php. Hệ thông sẽ gọi ra file tpl ở theme bạn đang dùng nếu không tồn tại file đó thì sẽ tiếp tục tìm đến file đó trong theme default, admin_default nếu không tồn tại thì sẽ báo lỗi. -> lệnh $xtpl->assign có chức năng gán giá trị cho biến trong xtpl. có thể là biến thông thường cũng có thể là mảng. -> lệnh $xtpl->parse, $xtpl->text( 'main' ) ta sẽ hiểu thông qua ví dụ cụ thể. Nhắc đến xtpl ta không thể không nhắc đến file theme.php (ngang hàng với file action.php). File này chứa tất cả cấu trúc xtpl. Nhưng không bắt buộc phải có nó, xtpl ta có thể dùng bất kì nơi nào. Để cho nhất quán, bài học này chúng ta sẽ dùng đến nó. Cấu trúc xtpl thông thường sẽ gọi các file có đuôi là tpl nhưng không nhất thiết phảo như thế, trong khi viết, để cho dễ dàng thao tác với chúng ta có thể chuyển lại chúng thành html và dùng các trình soạn thảo HTML để làm việc, sau khi hoàn tất ta sẽ chuyển trở lại thành tpl. Bây giờ ta sẽ đi vào ví dụ cụ thể. Đầu tiên là phần admin. Tạo thư mục và file như sau: themes/admin_default/modules/quanlihs/main.tpl. Nội dung file mail.tpl: <!-- BEGIN: main --> <table class="tab1"> <thead> <tr> <td> {LANG.stt}
Nhìn vào hai đoạn code trên ta thấy rằng: Cấu trúc file main.tpl không khác gì một file HTML. Cần chú ý đến thẻ <!-- BEGIN: main --> và
END: main --> đây là dấu hiệu cho biết bắt đầu và kết thúc của lệnh $xtpl->parse('main'); đối với những lệnh $xtpl->parse tiếp theo đặt trong main thì ta sẽ sử dụng lệnh $xtpl->parse('main.loop');. Chúng đặt nối tiếp nhau bởi dấu ".". Để trả về nội dung HTML ta sử dụng lệnh $xtpl->text('main'). Lưu ý đối với những nội dung nằm ngoài <!-- BEGIN: main --> và <!-- END: main --> chúng sẽ được bỏ qua. Lợi dụng đặc tính này ta chuyển file tpl sang html và viết tương tự như viết HTML sau khi viết xong ta sẽ cắt bỏ tất cả những phần ngoài hai thẻ này đi còn lại phần cần thiết. Đối với lệnh $xtpl->assign mà giá trị là biết đơn thì trong tpl chỉ cần gọi ra bằng {ten_bien} còn nếu là mảng thì để tham chiếu đến phần tử ta dùng {ten_bien.phan_tu}. Vừa rồi là phần admin,tiếo theo tới bên ngoài site. Bên ngoài site ta càn tạo thêm một file theme.php (không nhất thiết phải có) lưu ngang hàng với file action.php với nội dung như sau: /** * @Project NUKEVIET-MUSIC * @Author Phan Tan Dung () * @copyright 2011 * @createdate 26/01/2011 09:17 AM */ if ( ! defined( 'NV_IS_MOD_QUANLY' ) ) die( 'Stop!!!' ); function nv_quanly_main ( $data ) { global $module_file, $lang_module, $module_info; $xtpl = new XTemplate( "main.tpl", NV_ROOTDIR . "/themes/" . $module_info['template'] . "/modules/" . $module_file );
file theme.php thực chất là các function làm nhiệm vụ thực hiện thao tác với xtpl, nếu không cần file này ta có thển thục hiện ngay trong file main.php. Tiếp tục sửa lại file main.php như sau: