我想更新用户配置文件记录,但是在提交时,弹出一个错误消息“从空值创建默认对象”,当我删除 if 语句并只键入 var_dump($data),, 时,它运行顺利,并显示所有数据,但在 if 命令的存在下,弹出错误。我不知道为什么会这样,请帮忙class home extends Model{ protected $table="homes"; public static function upstore($data){ $firstname=Input::get('fname'); $lastname=Input::get('lname'); $phone=Input::get('phone'); $address=Input::get('address'); $profileimage=Input::get('pimage'); $password=Input::get('pswrd'); $confirmpassword=Input::get('cpswrd'); if( $firstname != '' ){ $homes->fname = $firstname; } if( $lastname != '' ){ $homes->lname = $lastname; } if( $phone != '' ){ $homes->phone = $phone; } if( $address != '' ){ $homes->address = $address; } if( $profileimage != '' ){ $homes->pimage = $profileimage; } if( $password != '' ){ $homes->pswrd = $password; } if( $confirmpassword != '' ){ $homes->cpswrd = $confirmpassword; } $homes->save(); } }它显示这个错误从空值创建默认对象
2 回答
慕村225694
TA贡献1880条经验 获得超4个赞
在第一个 if 语句之后,您尝试将一个属性设置为一个值,但您从未将 初始化$homes
为任何对象。
所以上面的 if 语句:
$homes = new home;
婷婷同学_
TA贡献1844条经验 获得超8个赞
正如我所看到的,您的模型中有 @upstore 方法。我可以在这里看到一些问题:
你到底是为了什么而使用控制器?仅用于显示视图?控制器是将输入请求转换为输出请求的应用程序的一部分,因此请将此逻辑切换到控制器中,因为如果您自己保留此约定,您在获得工作时很容易遇到一些麻烦。
if ($user, $address..) - 为什么不使用 Laravel 验证器?=)
您的正确方法
!= ''
是:(Request::has('field')
不要以为我这么说只是因为我想看起来更聪明,但这些错误会使您的代码在您开始在团队中工作时立即拒绝。
回到答案。我相信如果你修复了所有这些东西,代码应该可以正常工作。
- 2 回答
- 0 关注
- 130 浏览
添加回答
举报
0/150
提交
取消