主要内容:
1, 模块(访问数据库,链接到组件,数据基本流向)
2, 组件CRUD(MVC模式,访问数据库,表单提交,AJAX提交,数据基本流向)
3, 文字和代码为主,截图为辅,暂不解释相关原理(后续)
Windows7+EasyPHP5.3.9+Navcat for MySQL+Zend Studio10.0.0(PHP5.4)+浏览器
不用NetBeans了,因为Zend Studio界面、快捷键等确实都很好,也已习惯Eclipse(MyEclipse)的风格。
细节:
1 简单创建单一数据表(饮料表):表前缀_drink。
SET FOREIGN_KEY_CHECKS=0; -- ---------------------------- -- Table structure for stu_drink -- ---------------------------- DROP TABLE IF EXISTS `stu_drink`; CREATE TABLE `stu_drink` ( `ID` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) NOT NULL, `produceDate` date NOT NULL, `validateDate` date NOT NULL, `manufacturer` varchar(255) NOT NULL, `volume` decimal(5,1) DEFAULT NULL, `brand` varchar(255) DEFAULT NULL, `price` decimal(3,1) DEFAULT NULL, PRIMARY KEY (`ID`)) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8; -- ---------------------------- -- Records -- ----------------------------
stu_换成自己的表前缀。
2 开发模块(饮料提示):mod_drinktip,只显示编号ID和名称两列数据,放在模板的自定义position-7位置,菜单分配为“在所有的页面上”。
饮料提示模块文件结构和代码:
helper.php文件源代码:
getQuery ( true ); $query->select ( $db->quoteName ( array ( 'ID', 'name', 'price' ) ) )->from ( $db->quoteName ( '#__drink' ) )->order ( 'produceDate DESC' ); $db->setQuery ( $query ); $rows = $db->loadAssocList (); return $rows; }}
mod_drinktip.php文件源代码:
tmpl/default.php文件源代码:
所有index.html文件代码:
mod_drinktip.xml文件代码:
饮料提示 bobrave.shao September 2013 1.0.0 A simple drinktip module. mod_drinktip.xml index.html mod_drinktip.php helper.php tmpl/index.html tmpl/default.php
至此,mod_drinktip开发完毕,压缩zip包,扩展-扩展管理-安装-浏览-上传并安装-安装成功->扩展-扩展管理-模块管理-选中“饮料提示”-编辑-详细(选择位置)-菜单分配(选择模块分配)-保存/保存并关闭。
访问前端网站首页http://<host>:<port>/<sitename>
往数据表stu_drink中插入两、三条数据,效果如下: