우선 프랑스어입니다. 영어가 나쁘지 않기를 바랍니다. ^^ 'Symfony3에 문제가있어서 해결 방법을 모르겠습니다. 그것.Symfony - 동적 드롭 다운 목록이 편집 할 때만 작동하지 않습니다.
3 개의 드롭 다운 목록이있는 양식이 있습니다. 주제 2 개가 기관 및 센터와 관련되어 있습니다. 한 기관은 여러 센터를 가질 수 있습니다. 따라서 대행사를 선택하면 센터 목록이 업데이트됩니다. 세 번째 드롭 다운 목록은 범주입니다. 그것들은 모두 같은 이름을 가진 엔티티와 관련이 있습니다.
는 심포니, 나는 공식 문서를 따라 그렇게하려면 http://symfony.com/doc/3.0/form/dynamic_form_modification.html#form-events-submitted-data모든 창조의 형태로 잘 작동합니다. 그러나 동일한 드롭 다운 목록을 사용하여 편집 할 때 같은 양식을 사용하면 Ajax 요청이 작동하지 않습니다./ 세 번째 드롭 다운 목록의 카테고리가 null로 설정됩니다.
catch되지 않은 PHP 예외 심포니 \ 구성 요소 \ PropertyAccess \ 예외 \의 InvalidArgumentException : "유형의 예상 인수"EDVS \ SinistreBundle \ 법인 \ Categorie " " C에서 "주어진"NULL : \ WAMP \ WWW \ SinistraV2 \ 업체 \ 심포니 \ 심포니 \ SRC \ 심포니 \ 구성 요소 \ PropertyAccess \ PropertyAccessor.php 라인 (254)
그것은 내 2 다른 사람이 드롭 다운 목록을하지만 분명히,이 문제는 함께 할 수 없다. 이 오류는 편집 양식에서 대행사를 선택하면 더 명확 해집니다. 이렇게하면 Ajax 요청이 시작되고 목록을 센터로 업데이트해야하지만 그렇지 않습니다.
스택 추적을 보면 setCategory() 함수에 전달 된 매개 변수가 null입니다.
컨트롤러 및 formType 파일에서 확인한 결과 내 범주가 null이 아닙니다. 드롭 다운 목록은 사용 가능한 범주로 채워지고 데이터베이스에 유지되는 범주로 설정됩니다. 여기
, 내 "formType"파일 :class SinistreType extends AbstractType
{
/**
* @param FormBuilderInterface $builder
* @param array $options
*/
public function buildForm(FormBuilderInterface $builder, array $options)
{
// Récupération des sous-types, passés en paramètre via les options du form (voir aussi function configureOptions plus bas)
$sousTypeSinistre = $options['sousTypeSinistre'];
$em = $options['em'];
$builder
[...]
->add('categorie', EntityType::class, array(
'class' => 'EDVSSinistreBundle:Categorie',
'placeholder' => 'Choisir une catégorie',
'choice_label' => 'intituleCat',
))
[...]
->add('save', SubmitType::class);
;
/**
* Liste déroulante dynamique
* Selon l'agence sélectionnée, la liste de centres correspondant change
*/
$centresModifier = function (FormInterface $form, Agence $agence = null) {
/**
* Si l'agence passée en param est null, $centres reçoit un tableau vide,
* sinon $centres prend comme valeur la liste des centres rattachés à l'agence
*/
$centres = null === $agence ? array() : $agence->getCentres();
// Ajout, dans le formulaire, de la liste déroulante contenant les centres récupérés précédemment
$form->add('centre', EntityType::class, array(
'class' => 'EDVSAgenceCentreBundle:Centre',
'placeholder' => 'Choisir un centre',
'choices' => $centres,
'choice_label' => 'nom',
));
};
// Evénement appelé au moment de la construction du formulaire
$builder->addEventListener(FormEvents::PRE_SET_DATA, function (FormEvent $event) use ($centresModifier, $em) {
$data = $event->getData(); // Entité Sinistre
$form = $event->getForm();
// Dans le cas d'une modification (données provenant de la BDD)
if ($data->getCentreUtilise()) {
// Récupération du centre & de l'agence par rapport au centreUtilisé & à l'agenceUtilisée liés au dossier en cours de modification
$centre = $em->getRepository('EDVSAgenceCentreBundle:Centre')->getCentreByNom($data->getCentreUtilise()->getNom());
$agence = $em->getRepository('EDVSAgenceCentreBundle:Agence')->getAgenceByNom($data->getCentreUtilise()->getAgenceUtilisee()->getNom());
// Sélection de l'agence & du centre dans les listes déroulantes correspondantes
$data->setCentre($centre[0]);
$data->setAgence($agence[0]);
// Affichage de la liste des agences disponibles & des centres correspondants
$centresModifier($form, $data->getAgence());
} else { // Dans le cas d'une création (données vides)
$centresModifier($form, $data->getAgence());
}
});
// Evénement appelé juste après que le formulaire ait été validé, concerne le champ "agence" seulement
$builder->get('agence')->addEventListener(FormEvents::POST_SUBMIT, function(FormEvent $event) use ($centresModifier) {
$form = $event->getForm();
$agence = $form->getData();
$centresModifier($form->getParent(), $agence);
});
}
/**
* @param OptionsResolver $resolver
*/
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults(array(
'data_class' => 'EDVS\SinistreBundle\Entity\Sinistre',
'sousTypeSinistre' => null, // Déclaration du paramètre "typeSinistre" pour qu'il puisse être reconnu comme option (transfert du param controller vers form)
'em' => null, // Idem
));
}
}
자바 스크립트 부분 : 여기 같은 문제가 될 것으로 보인다
$(document).ready(function() {
var agence = $('#sinistre_edit_agence');
/* Actualisation de la liste déroulante des centres en fonction de l'agence sélectionnée */
agence.change(function() {
// Animation "Chargement en cours"
toggleLoading();
var form = $(this).closest('form');
var data = {};
data[agence.attr('name')] = agence.val();
$.ajax({
url : form.attr('action'),
type: form.attr('method'),
data : data,
success: function(html) {
$('#sinistre_edit_centre').replaceWith(
$(html).find('#sinistre_edit_centre')
);
toggleLoading();
},
error: function(error) {
console.error(error);
toggleLoading();
}
});
});
});
: Symfony 2: Dynamic Form Event returns InvalidArgumentException only when editing
그러나 대답이 없으며 내가 뭘 잘못하고 있는지 정말로 모른다. 폼 이벤트를 올바르게 사용하지 않는다고 생각합니다. 완전히 새로운 것입니다.
나는 도움을 얻을 수 있기를 바랍니다. 미리 감사드립니다.
AJAX 요청이 생성 양식에서 올바르게 실행되고 있는지 확인 했습니까? 카테고리 :> 대행사 -> 센터? – nbonniot
예, 작성 양식에 대해 Ajax 요청이 올바르게 실행 중입니다. 편집에만 실패합니다. 대행사 및 센터는 직접 관련이 있습니다. 센터는 대행사와 연결되어 있습니다. 대행사는 하나 또는 여러 센터 (ManyToOne 관계)에 연결됩니다. 카테고리가 대행사 또는 센터에 직접 연결되어 있지 않습니다. 3 개의 엔티티는 다른 엔티티와 관련이 있으며이 엔티티를 수정하려고하면 버그가 나타납니다. – Heybee