中国设计联盟
联网
平面设计 画册 VI欣赏 包装 CG-插画 搜索 个人网页 Alexa排名 CSS 建站资源 下载专区 JS特效 品牌服装 服装院校 专题欣赏 SEO 图标欣赏 专题
网站建设 域名注册 虚拟主机 广州网站设计 域名注册 广州网站建设 上海网站建设 虚拟主机 广州网页设计  虚拟主机 域名注册 acg王国 ACG玩家
求创科技
网站建设
中国福网
招聘求职
中国互联
艺魂宝库网
中资源
当前位置:网络学院首页 >> 编程开发 >> php >> PHP中类的使用,面向对象的思路

PHP中类的使用,面向对象的思路

来源:中国设计秀    作者:    点击:90     加入收藏    发表评论
0
顶一下
  以前开始学习PHP的时候也是使用的面向结构的思想,因为我们一开始接触C++的时候就是使用的面向结构的代码。虽然后来学习了类,但是还是对于面向结构比较喜欢吧。
 
  之前的很长一段时间我对于类或者面向对象都不是很清楚,问了一个师兄,师兄给了我一个比方,说的很是形象“好比两个人打架,你要用程序去描述它,面向结构了,你是把每一步的对打都写好了,比如对方出什么招数,你出什么招数,必须每一步都写出来,面向对象的方法了,你要把打架的过程拆分成几个部分,打架前,打架中,及其之后”,虽然这个比方不是很确切,但是让我对于面向对象有了那么一点认识。
 
  现在对于PHP的面向对象的做法,已经学习了一段时间,做的系统里面也有是用面向对象的方法做的了。
 
  说一说面向对象的好处吧,它可以让系统很好的模块化,可以让很多的程序员一起工作,提高了编码的效率。对于整个系统的维护和更新也方便了很多的。
 
  下面帖个类出来,大家感受一下吧。这个是一个数据库链接和操作的基础类,它为其他类说引用吧。
 

<?php
/*
数据库类文件:class_database.php
数据库操作类,本类是其他类操作的基础,即其他类函数的实现一般情况下通过数据库类实现
创建世间:2007年5月17日
*/
include_once("config.inc"); //包含系统配置文件
class data_class
{
//属性
private  $host; //服务器名
private  $user; //用户名
private  $pwd; //密码
private  $name; //数据库名
private  $connection; //连接标识

//方法
//__get():获取属性值
function __get( $property_name){
if(isset( $this-> $property_name))
{
return( $this-> $property_name);
}
else
{
return(NULL);
}
}
//__set():设置单个私有数据属性值,用于少量的修改数据
function __set( $property_name,  $value)
{
 $this-> $property_name =  $value;
}
//__construct:构造函数,建立连接,在函数建立时自动调用建立,原则新建对象时不显式调用
function __construct()
{
 $this->host=sys_conf:: $dbhost; //使用sys_conf类的静态属性
 $this->user=sys_conf:: $dbuser;
 $this->pwd=sys_conf:: $dbpswd;
 $this->name=sys_conf:: $dbname;
//建立与数据库的连接
 $this->connection=mysql_connect ( $this->host, $this->user, $this->pwd);//建立连接
mysql_query("set names 'utf8'");//字符集的统一
mysql_select_db(" $this->name",  $this->connection); //选择数据库挑战杯
}
//__destruct:析构函数,断开连接,在函数执行完毕时自动调用析构。实现关闭数据库的连接,保证数据库数据的安全
function __destruct()
{
mysql_close( $this->connection);
}
//增删改:参数 $sql为Insert update
function execute( $sql)
{
mysql_query( $sql);
//echo "写入数据库成功了";
//echo "我是dataclass类的execute函数";
}//execute
//查:参数 $sql为Insert语句
//返回值为对象数组,数组中的每一元素为一行记录构成的对象
function query( $sql)
{
 $result_array=array(); //返回数组
 $i=0; //数组下标
 $query_result=@mysql_query( $sql, $this->connection); //查询数据
while( $row=@mysql_fetch_object( $query_result))
{
 $result_array[ $i++]= $row;
}//while
return  $result_array;
}
//获得查询结果的纪录数函数
function result_query( $sql)
{
 $result=mysql_query( $sql);
 $result_c=mysql_num_rows( $result);
return  $result_c;
}
}
?>

2007-06-29 11:38:00    出处:
Google
热点文章/相关文章
网站地图 | 关于我们 | 联系我们 | 网站建设 | 广告服务 | 版权声明 | 免责声明 | 网站公告 | 友情链接 | 留言 | 旧版入口