mvc只是一种设计模式而已,一度被认为model 1,也就是服务器语句与html语句杂糅的php,其实不用任何框架,仅仅利用原生态的javascript ajax也可以对其进行mvc设计。由于什么都没有用,因此对ie6的兼容性是非常强的。还是《【php】数据库的增删改查和php与javascript之间的交互》(点击打开链接)那个页面的,对数据库增删改查的内容,希望各位能推广到整个网站。
一、基本目标
整个网页实现效果如下,用户输入完表单马上就有效果。
二、基本思想
首先,在test数据库中有一张这样的用户信息表,建表的时候注意检查一下那些数据库字段的编码是否是utf-8,一些mysql在安装时候没有改默认的编码latin1的,不然一会儿你打死无法存中文。
然后,整个网页工程结构如下图:
在view.php中网页中不进行任何刷新,利用原生态的javascript ajax,直接完成v-c层的交互。c-m层的交互通过include语句,引入m层的业务逻辑类中方法,通过类参数的传递完成。
同时,c、m层的php拒绝直接输入网址访问。这里不像jsp或者asp,c层、m层都是编译之后的java文件或者c#文件,根本就访问不了。我们还要对其进行保护。
三、制作过程
1、view层就一个简单的view.php,其布局如下,没什么好说的,非常简单的html布局。同时,注意,本页面:
(1)没有设置表单,所有表单提交的动作,通过button触发相应的javascript而触发。
(2)各个组件的id,一会儿在javascript用到。其中用户信息表、修改id的下拉框都是通过下面的脚本ajax而加载的。
(3)布局中,包括一会儿的脚本在内没有任何php代码,便于各位布局。你把后缀名改成.html也能够正常运行。什么叫做真正的view层?这就是了,没有任何的服务器代码。
用户信息表用户信息表如下:
插入数据
用户名:密码:go!修改数据
用户名密码go!
其实整个view层的精髓在于下面的javascript脚本。view层就无须使用到xajax这个插件了,《【php】xajax helloworld》(点击打开链接)。直接用原生态的javascript写。虽然代码量比起jquery等前端框架较多,记住不容易。从建立ajax对象,设置ajax请求头,处理ajax文本都要自己写,但在开发过程中,只是复制粘贴而已。因此可以观察到,所有的ajax交互函数都大同小易。拿foralluserinfo();这个函数来重点说明怎么v-c层怎么通过ajax交互。
2、controll层
controll层的页面都与view层中的javascript函数一一对应。
比如dbupdate.php就对应view.php中的update()函数。通过如下两句对应起来。
var url=dbupdate.php;xmlhttprequest.open(post,url,true);
(1)dbupdate.php
非常简单的页面,拿到前端送过来的两个数据,则进行与model层的交互,完成数据库的操作。修改数据库,数据库是不会返回任何结果的,因此也没有什么数据给前端的。如果拿不到前端送过来的参数,那一定是恶意用户,通过输入网址非正常打开此页。c层m层一般是不给你打开的。
modify(update user set .$rowname.='.$rowtext.' where id=.$userid.;); }?>
(2)dbinsert.php
插入数据同样的道理了,不再赘述。对应于前端的insert()函数
modify(insert into user(username,password) values ('.$username.','.$password.');); }?>
(3)dbtotal.php
这一页是用来查询数据库有多少条结果,我们在修改数据的下拉列表就要提供给用户多少个id,给用户指定修改。
对应于view.php中的fortotal()函数。这一页是有返回结果的。因此dbtotal.php就把这个结果用echo打印出来,前端通过:
var total=parseint(xmlhttprequest.responsetext);
这一句中的xmlhttprequest.responsetext拿到,前端的javascript必须强制指明这是数字,否则则出现7+1=71的神运算。javascript把数字当字符串了,也没办法了,毕竟所有变量都是var。php则都是美元$。
这一页就无须保护了,毕竟肯定要给用户看的。
gettotal(); echo $total;?>
(4)dbselect.php
这一页其实和dbtotal.php一样,不过变成了构造一个表格,送给前端view.php的foralluserinfo()。foralluserinfo()得到的数据其实一段html文本,直接通过.innerhtml放上去就可以了。
getalluserinfo();?>
id用户名密码
这页有html打死都不能与php代码混在一起的强迫症患者,请自行把所有html的代码,给成echo输出,反正我就只能给出这样的一个方案了。
3、model层
这一层的所有方法都与c层的页面存在对应关系。
首先都公用一个数据库连接函数。之后各自在方法中调用,最后各自查询完毕则关闭这个连接。
然后,可以注意到上面的controll层的dbupdate.php与dbinsert.php公用此类的一个方法。这主要是考虑到,都是传递一个sql语句过来,然后没有返回结果,因此可以合在一起了。而查询数据库的所有数据与查询数据库的数据数量的返回结果是不同的,因此分开两个方法。
四、总结与展望
上面的制作过程最好合在一起看,反正我只能这样分层贴了。v-c,c-m一直在交互,从未被割裂,根本停不下来。对比与《【php】数据库的增删改查和php与javascript之间的交互》(点击打开链接)这个以model1模式创作的工程,页面虽然增多,但是模块更加地清晰。
反正mvc仅仅是一种设计模式、设计思想而已,在php同样也能够实现。在jsp对这种模式的吹嘘是言过其实了,主要是jsp的部分创作者,不停地对于框架的使用,而忘记了这门语言的本质。
我觉得这个例子,再次证明了语言只是思想表达的载体。无插件无框架,纯html+css与纯javascript加php就能够实现,兼容ie6。如果你打包一样,放上防注入函数,完全可以成为自己的框架的。
对比与jsp与asp,我在写php的时候更加舒服,告别了myeclipse/eclipse与visual studio的卡爆,用着早已被批得一毛不是dreamwaver,甚至还可以用记事本写着网页,半点不卡。一台垃圾配置的winxp就能够创造出好的网站。关键是你的语言基本功问题了。少做点喷子,多做点工程。多接触几门编程语言。