我的项目中有一个视图部分,并使用CGridView列出表中的所有数据,在网格中也有一个编辑和删除选项来编辑和删除特定的行。
我遇到了编辑部分。我正在研究如何在editjob.php中显示特定的行数据,我做了一些事情,但没有用。我的代码如下,
在我的视图作业部分中使用CgridView,
'buttons' =>array('update'=>array(
'label'=>'edit',
'url'=>'Yii::app()->controller->createUrl("UpdateJob",array("id"=>$data["id"]))',
))
在Model UpdateJob中:
public function edit()
{
$criteria=new CDbCriteria;
$criteria->find('id','Admin',true);
return new CActiveDataProvider('viewjob', array(
'criteria'=>$criteria,
// 'sort'=>array(
// 'defaultOrder'=>'key_skills ASC',
// ),
));
控制器中的:
public function actionUpdateJob()
{
if(isset($_GET['id']))
{
$id=$_GET['id'];
}
$model = new UpdateJob('edit');
$params = array('model' => $model,'id' => $id //passing the id like this
);
$this->render('update', $params);
}
最后在视图中写了类似的东西,但显示错误
<div class="row">
<?php echo $form->labelEx($model,'Company Name'); ?>
<?php echo Chtml::textField('posted_by',UpdateJob::model()->FindByPk($model->id)->posted_by); ?>
<?php echo $form->error($model,'posted_by'); ?>
</div>
我正在走上正轨。
答案 0 :(得分:0)
您正在加载新模型而不是获取现有模型。替换此行:
$model = new UpdateJob('edit');
通过这一行:
$model = UpdateJob::model()->findByPk($id);
要保存数据,请执行以下操作:
if(isset($_POST['UpdateJob'])) {
$model->scenario='edit';
$model->attributes=$_POST['UpdateJob'];
if($model->save())
$this->redirect(array('admin');
}