魔术方法在框架中的应用

刚才 我们用TP做了一个用户注册,注册时的代码在下面 
按我们以前的做法, 
把POST来的数据,拼接sql,然后查询. 
但是在TP中的做法,有点奇怪, 
他是把收到的信息, 
赋给了一个对象的属性. 
然后对象->add()方法,就写入到数据库了. 
很方便 . 
思考: 
1: userModel就有username属性供你去赋值吗? 
2: 如果$userModel->xxx属性,是保护的, 
而我的表,又有一个字段,恰好也叫xxx, 
那么 我自然是 $user->xxx = $_POST['xxx']; 
这不就出错了吗? 
3:还有一个问题: userModel 有一些属性,很正常,比如有5个属性 
a,b,c,d,e 
我在注册时, 又动态设置了属性, f,g,h,i 
疑问: 在拼接sql时,要把a,b,c,d,e忽略掉才行. 
又怎么忽略. 
答:用魔术方法来解决 
通过__set()方法, 
把属性的设置--->都放到数组里. 
处理时,专门处理这个数组就可以了. 
这样,就不会和其他属性相冲突 
*/ 
/* 
TP中的一段用户注册代码 
        $userModel->username = $_POST['username']; 
        $userModel->email = $_POST['email']; 
        if($num = $userModel->table('user')->add()) { 
            echo '注册成功'; 
        } else { 
            echo 'fail'; 
        } 
*/ 
class UserModel { 
    protected $email = 'user@163.com'; 
    protected $data = array(); 
    public function __set($k,$v) { 
        // $this->$k = $v; //并没有真正赋成自己的属性 
        $this->data[$k] = $v; // 而是放在一个数组里 
    } 
    public function __get($p) { 
        return isset($this->data[$p]) ? $this->data[$p] : NULL; 
    } 
    public function __unset($p) { 
        unset($this->data[$p]); 
    } 
    public function __isset($p) { 
        return isset($this->data[$p]); 
    } 
    public function add() { 
        $sql = 'insert into table ('; 
        $sql .= implode(',',array_keys($this->data)); 
        $sql .= ') values (\''; 
        $sql .= implode("','",array_values($this->data)); 
        $sql .="')"; 
        return $sql; 
    } 
} 
echo '<pre>'; 
$userModel = new UserModel(); 
print_r($userModel); 
$userModel->username = 'lisi'; 
$userModel->email = 'lisi@126.com'; 
print_r($userModel); 
//echo $userModel->add(); 
unset($userModel->email); 
print_r($userModel); 
?> 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值