我想编辑诸如(name,username,email email ..(诸如数据库中的表单的字段时都有问题。我应该做什么,我想保持相同的状态(我不想更改它(,我只想编辑我选择的字段。
ps:我在用户名字段中也遇到了这个问题,但是我设法通过"仅读取"来解决它,但我无法对密码字段进行相同的操作。这些字段属于两个不同实体的用户和开发器。我将共享树枝(表单编辑(,FormBuilder(USERTYPE(和USERCONTROLLER
{{ form_start(form) }}
<div id="main-wrapper" >
<div class="page-wrapper">
<div class="row">
<div class="col-12">
<div class="card">
<div class="card-body formEdit">
<form class="m-t-40" novalidate>
<div class="form-group form-md-line-input has-success" >
<label class="col-md-2 control-label" for="form_control_1">Nom</label>
<div class="col-md-8" >
<input type="text" class="form-control" id="form_control_1" required data-validation-required-message="This field is required" {{ form_widget(form.firstname,{'attr':{'class':'form-control'}}) }}
<div class="form-control-focus"> </div>
</div>
</div>
<div class="form-group form-md-line-input has-success">
<label class="col-md-2 control-label" for="form_control_1">Prénom</label>
<div class="col-md-8">
<input type="text" class="form-control" id="form_control_1" required data-validation-required-message="This field is required" {{ form_widget(form.lastname,{'attr':{'class':'form-control'}}) }}
<div class="form-control-focus"> </div>
</div>
</div>
<div class="form-group form-md-line-input has-success" >
<label class="col-md-2 control-label" for="form_control_1">id</label>
<div class="col-md-8" >
<input readonly="" type="text" class="form-control" id="form_control_1" required data-validation-required-message="This field is required" {{ form_widget(form.user.username,{'attr':{'class':'form-control'}}) }}
<div class="form-control-focus" > </div>
</div>
</div>
<div class="form-group form-md-line-input has-success" >
<label class="col-md-2 control-label" for="form_control_1">Solde conge annuel</label>
<div class="col-md-8" >
<input type="text" class="form-control" id="form_control_1" required data-validation-required-message="This field is required" {{ form_widget(form.user.soldecongeannuel,{'attr':{'class':'form-control'}}) }}
<div class="form-control-focus" > </div>
</div>
</div>
<div class="text-xs-right col-xs-12 selectbutton" align="center">
<button type="submit" id="btn-save" name="btn-save" class="btn btn-primary">Sauvgarder</button>
<button onclick="history.go(-1);" type="button" class="btn btn-default">Annuler</button>
</div>
</form>
</div></div></div></div>
</div></div>
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder
->add('email', 'email', array(
'label'=>'Email *',
'attr'=>array('class'=>'form-control',
'onchange'=>'check_email(value)'),
'label_attr'=>array('class'=>'label-control red')))
->add('username', 'text', array(
'label'=>"Identifiant *",
'attr'=>array('class'=>'form-control',
'onchange'=>'check_username(value)'),
'label_attr'=>array('class'=>'label-control red')))
->add ('password', 'repeated', array (
'type' => 'password',
'first_name' => "password",
'second_name' => "confirm",
'first_options' => array('label' => 'Mot de passe *',
'attr'=>array('class'=>'form-control'),
'label_attr'=>array('class'=>'label-control red')),
'second_options' => array('label' => 'Confirmation mot de passe *',
'attr'=>array('class'=>'form-control'),
'label_attr'=>array('class'=>'label-control red')),
'invalid_message' => "Mot de passe incorrect !",
'attr'=>array('class'=>'form-control'),
'label_attr'=>array('class'=>'label-control')
))
->add('soldecongeannuel', 'integer', array(
'label'=>"Solde congé annuel *",
'attr'=>array('class'=>'form-control',
'onchange'=>'check_username(value)'),
'label_attr'=>array('class'=>'label-control red')))
->add('soldemaladie', 'integer', array(
'label'=>"Solde maladie *",
'attr'=>array('class'=>'form-control',
'onchange'=>'check_username(value)'),
'label_attr'=>array('class'=>'label-control red')))
->add('soldeautremotif', 'integer', array(
'label'=>"Solde autre motif *",
'attr'=>array('class'=>'form-control',
'onchange'=>'check_username(value)'),
'label_attr'=>array('class'=>'label-control red')))
;
}
public function editAction($username, Request $request) {
//$em = $this->getDoctrine()->getManager();
$userManager = $this->get('fos_user.user_manager');
$user = $this->getUser();
if(!is_object($user))
return $this->redirect($this->generateUrl('fos_user_security_login'));
您可以删除您不想从USERTYPE类中编辑的字段或构建其他formType类以在您的编辑中使用。
例如,没有密码字段:
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder
->add('email', 'email', array(
'label'=>'Email *',
'attr'=>array('class'=>'form-control',
'onchange'=>'check_email(value)'),
'label_attr'=>array('class'=>'label-control red')))
->add('username', 'text', array(
'label'=>"Identifiant *",
'attr'=>array('class'=>'form-control',
'onchange'=>'check_username(value)'),
'label_attr'=>array('class'=>'label-control red')))
->add('soldecongeannuel', 'integer', array(
'label'=>"Solde congé annuel *",
'attr'=>array('class'=>'form-control',
'onchange'=>'check_username(value)'),
'label_attr'=>array('class'=>'label-control red')))
->add('soldemaladie', 'integer', array(
'label'=>"Solde maladie *",
'attr'=>array('class'=>'form-control',
'onchange'=>'check_username(value)'),
'label_attr'=>array('class'=>'label-control red')))
->add('soldeautremotif', 'integer', array(
'label'=>"Solde autre motif *",
'attr'=>array('class'=>'form-control',
'onchange'=>'check_username(value)'),
'label_attr'=>array('class'=>'label-control red')))
;
}
您还应该查看Symfony表单文档,尤其是渲染部分,并相应地调整您的树枝以确保正确渲染所有字段。
- https://symfony.com/doc/current/forms.html
- https://symfony.com/doc/current/form/form/form_customization.html