注文書のdeatilsで購入注文を維持するために、1対多の関係を表現したいと思います。購入詳細注文リストを各ディテールのテーブル行をインクリメントして追加しようとしました。私は、このエラー=>タイプ「PurchaseOrderDetailType」をロードできませんでしたを得た後、このカスタムフォームフィールドを読み込めませんでした。Symfony 3で入力してください
class PurchaseOrderType extends AbstractType
{
/**
* @param FormBuilderInterface $builder
* @param array $options
*/
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder
->add('supplier',EntityType::class, array(
'class' => 'AppBundle:Supplier',
'label'=>'Supplier',
'query_builder' => function (EntityRepository $er) {
return $er->createQueryBuilder('supplier')
->orderBy('supplier.name', 'ASC');
},
'choice_label' => 'name',
))
->add('purchaseOrderDetails',CollectionType::class,array(
'entry_type' => PurchaseOrderDetailType::class,
'allow_add' => true
))
->add('status');
}
/**
* @param OptionsResolver $resolver
*/
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults(array(
'data_class' => 'AppBundle\Entity\PurchaseOrder'
));
}
}
ようPurchaseOrderTypeのクラスでそれを使用して次に
class PurchaseOrderDetailType extends AbstractType{
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder->add('item',EntityType::class, array(
'class' => 'AppBundle:InvtItem',
'query_builder' => function (EntityRepository $er) {
return $er->createQueryBuilder('item')
->orderBy('item.description', 'ASC');
},
'choice_label' => 'description',
))
->add('unit_price')
->add('qty')
->add('price');
}
/**
* @param OptionsResolver $resolver
*/
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults(array(
'data_class' => 'AppBundle\Entity\PurchaseOrderDetails'
));
}
}
を次のように、 私はPurchaseOrderDetailTypeフォームタイプを開発しました10 500内部サーバーエラー - InvalidArgumentException
あなたはsymfonyの3もしくはsymfony 2.8とEntityType ::クラスの構文を使用している場合、あなたは入れなければならないの名前空間を逃しましたEntityType; ' –
ええ私はすべてのライブラリを正しくインポートしました。私はここでそれらを言及しませんでした。 – Sameera