不知道这是否是一个典型的问题,但不知道如何实现它。3张表:应用它的关系:
return array(
'company_info' => array(self::HAS_ONE, 'AppCompany', 'applicant_id'),
'region'=>array(
self::HAS_ONE,'AppRegion',array('company_region_id'=>'id'),
'through'=>'company_info'
),
'sector'=>array(
self::HAS_ONE,'AppSector',array('company_sector_id'=>'id'),
'through'=>'company_info'
),
);
AppCompany。关系:
return array(
'application' => array(self::BELONGS_TO, 'Application', 'applicant_id'),
'region' => array(self::BELONGS_TO, 'AppRegion', 'company_region_id'),
'sector' => array(self::BELONGS_TO, 'AppSector', 'company_sector_id'),
'goodsservices' => array(self::HAS_MANY, 'AppGoodsServices', 'company_id')
);
App.GoodsServices.Relations:
return array(
'company'=>array(self::BELONGS_TO, 'AppCompany', 'company_id'),
);
因此,一个用户添加了关于他的公司的信息(company_name、date_of_registration等),然后添加了该公司生产的一些商品/服务。如何在一个表单中收集、更新和查看所有这些信息?有可能吗?
我如何看待这一点:用户添加一些信息并满足字段:"商品和服务及其百分比"和两个字段-"商品和劳务"answers"百分比"以及添加更多按钮,他有6种商品要添加。因此,他点击添加更多按钮,每次出现下面的新字段时。但商品限制为5,因此在5个字段有信息后,该按钮将变为非活动状态。
在"提交"按钮之后,所有这些信息都会记录到它的表中。它可以从UPDATE按钮上的表中获取,并且可以在一个CDetailView中查看。
请说明如何至少在一般情况下实施谢谢
更新好的,一些工作已经完成了(不知道是否正确,但…):
我使用了此扩展:http://www.yiiframework.com/extension/esaverelatedbehavior/
现在我有:
public function actionCreate()
{
$model=new Application;
// Uncomment the following line if AJAX validation is needed
$this->performAjaxValidation($model);
if(isset($_POST['Application']))
{
$model->attributes=$_POST['Application'];
if(isset($_POST['AppGoodsServices']))
{
$model->goodsservices = $_POST['AppGoodsServices'];
}
if ($model->saveWithRelated('goodsservices'))
{
$this->redirect(array('view', 'id' => $model->id));
} else {$model->addError('goodsservices', 'Error occured while saving goods/services.'); }
}
$this->render('create',array(
'model'=>$model,
));
}
public function actionUpdate($id)
{
$model=$this->loadModel($id);
// Uncomment the following line if AJAX validation is needed
// $this->performAjaxValidation($model);
if(isset($_POST['Application']))
{
$model->attributes=$_POST['Application'];
if(isset($_POST['AppGoodsServices']))
{
$model->goodsservices = $_POST['AppGoodsServices'];
}
if ($model->saveWithRelated('goodsservices'))
{
$this->redirect(array('view', 'id' => $model->id));
} else {$model->addError('goodsservices', 'Error occured while saving goods/services.'); }
}
$this->render('update',array(
'model'=>$model,
));
}
public function loadModel($id)
{
$model=Application::model()->findByPk($id);
if($model===null)
throw new CHttpException(404,'The requested page does not exist.');
return $model;
}
在我的_form.php 中
<div id="goodsservices">
<?php
$index = 0;
foreach ($model->goodsservices as $id => $goods):
$this->renderPartial('goods/_form', array(
'model' => $goods,
'index' => $id,
));
$index++;
endforeach;
?>
</div>
和商品中的子表单_form:
<div style="margin-bottom: 20px; width:100%; clear:left;" class="crow">
<div class="row" style="float: left;">
<?php echo CHtml::activeLabelEx($model, '['.$index.']goods_and_services'); ?>
<?php echo CHtml::activeTextField($model, '['.$index.']goods_and_services', array('size' => 30, 'maxlength' => 150)); ?>
<?php echo CHtml::error($model, '['.$index .']goods_and_services'); ?>
</div>
<div class="row" style="float: left;">
<?php echo CHtml::activeLabelEx($model, '['.$index .']percentage'); ?>
<?php echo CHtml::activeTextField($model, '['.$index.']percentage', array('size' => 5)); ?>
<?php echo CHtml::error($model, '['.$index.']percentage'); ?>
</div>
<div class="row" style="float: left;">
<?php echo CHtml::link('Delete', '#', array('onclick' => 'deleteGoods(this, '.$index.'); return false;'));
?>
</div>
</div>
<div style="clear: both;"></div>
<?php
Yii::app()->clientScript->registerScript('deleteGoods', "
function deleteGoods(elm, index)
{
element=$(elm).parent().parent();
/* animate div */
$(element).animate(
{
opacity: 0.25,
left: '+=50',
height: 'toggle'
}, 500,
function() {
/* remove div */
$(element).remove();
});
}", CClientScript::POS_END);
?>
一切都可以,但我不明白如何制作一个批量的儿童创建(Goodssevices)模型。现在,它只显示UPDATE表单中的子项(我已经将一些记录直接放入DB),每个子项附近都有DELETE按钮。但是如何实现CREATE?所以,一个空行应该是可见的,我可以点击"添加行"添加其他行?
这是可能的。使用javascript,您应该在视图中创建其他项目,在控制器操作中,您将获得带有所有数据的$_POST,在一个事务中填充和验证所有模型。在更新操作视图中,您将显示带有phpforeach的相关模型。
这里有一个对您有用的代码示例。另请参阅评论。