Symfony-양식

Symfony는 HTML 양식을 쉽고 안전하게 처리 할 수있는 다양한 내장 태그를 제공합니다. Symfony의 Form 구성 요소는 양식 생성 및 유효성 검사 프로세스를 수행합니다. 모델과 뷰 레이어를 연결합니다. 사전 정의 된 모델에서 본격적인 HTML 양식을 작성하기위한 양식 요소 세트를 제공합니다. 이 장에서는 Forms에 대해 자세히 설명합니다.

양식 필드

Symfony 프레임 워크 API는 대규모 필드 유형 그룹을 지원합니다. 각 필드 유형을 자세히 살펴 보겠습니다.

FormType

Symfony 프레임 워크에서 양식을 생성하는 데 사용됩니다. 구문은 다음과 같습니다.

use Symfony\Component\Form\Extension\Core\Type\TextType; 
use Symfony\Component\Form\Extension\Core\Type\EmailType; 
use Symfony\Component\Form\Extension\Core\Type\FormType; 
// ...  

$builder = $this->createFormBuilder($studentinfo); 
$builder 
   ->add('title', TextType::class);

여기, $studentinfo 학생 유형의 엔티티입니다. createFormBuilderHTML 양식을 만드는 데 사용됩니다. add 메소드는add 양식 내부의 입력 요소. title 학생의 소유권 속성을 나타냅니다. TextType::classhtml 텍스트 필드를 나타냅니다. Symfony는 모든 html 요소에 대한 클래스를 제공합니다.

TextType

TextType 필드는 가장 기본적인 입력 텍스트 필드를 나타냅니다. 구문은 다음과 같습니다.

use Symfony\Component\Form\Extension\Core\Type\TextType; 
$builder->add(‘name’, TextType::class);

여기서 이름은 엔티티와 매핑됩니다.

TextareaType

텍스트 영역 HTML 요소를 렌더링합니다. 구문은 다음과 같습니다.

use Symfony\Component\Form\Extension\Core\Type\TextareaType; 
$builder->add('body', TextareaType::class, array( 
   'attr' => array('class' => 'tinymce'), 
));

EmailType

EmailType 필드는 HTML5 이메일 태그를 사용하여 렌더링되는 텍스트 필드입니다. 구문은 다음과 같습니다.

use Symfony\Component\Form\Extension\Core\Type\EmailType; 
$builder->add('token', EmailType::class, array( 
   'data' => 'abcdef', ));

PasswordType

PasswordType 필드는 입력 암호 텍스트 상자를 렌더링합니다. 구문은 다음과 같습니다.

use Symfony\Component\Form\Extension\Core\Type\PasswordType; 
$bulder->add('password', PasswordType::class);

RangeType

RangeType 필드는 HTML5 범위 태그를 사용하여 렌더링되는 슬라이더입니다. 구문은 다음과 같습니다.

use Symfony\Component\Form\Extension\Core\Type\RangeType; 
// ...  
$builder->add('name', RangeType::class, array( 
   'attr' => array( 
      'min' => 100, 
      'max' => 200 
   ) 
));

PercentType

PercentType은 입력 텍스트 필드를 렌더링하고 백분율 데이터 처리를 전문으로합니다. 구문은 다음과 같습니다.

use Symfony\Component\Form\Extension\Core\Type\PercentType; 
// ... 
$builder->add('token', PercentType::class, array( 
   'data' => 'abcdef', 
));

DateType

날짜 형식을 렌더링합니다. 구문은 다음과 같습니다.

use Symfony\Component\Form\Extension\Core\Type\DateType; 
// ... 
$builder->add(‘joined’, DateType::class, array( 
   'widget' => 'choice', 
));

여기서 위젯은 필드를 렌더링하는 기본 방법입니다.

다음과 같은 기능을 수행합니다.

  • choice− 세 가지 선택 입력을 렌더링합니다. 선택 순서는 형식 옵션에서 정의됩니다.

  • text − 텍스트 유형 (월, 일, 연도)의 3 개 필드 입력을 렌더링합니다.

  • single_text− 날짜 유형의 단일 입력을 렌더링합니다. 사용자 입력은 형식 옵션을 기반으로 검증됩니다.

CheckboxType

단일 입력 확인란을 만듭니다. 부울 값이있는 필드에는 항상 사용해야합니다. 구문은 다음과 같습니다.

use Symfony\Component\Form\Extension\Core\Type\CheckboxType; 
// ...  
$builder-<add(‘sports’, CheckboxType::class, array( 
   'label'    =< ‘Are you interested in sports?’, 
   'required' =< false, 
));

RadioType

단일 라디오 버튼을 만듭니다. 라디오 버튼을 선택하면 필드가 지정된 값으로 설정됩니다. 구문은 다음과 같습니다.

use Symfony\Component\Form\Extension\Core\Type\RadioType; 
// ...  
$builder->add('token', RadioType::class, array( 
   'data' => 'abcdef', 
));

라디오 버튼은 선택 취소 할 수 없으며 같은 이름의 다른 라디오 버튼이 선택 될 때만 값이 변경됩니다.

반복 유형

이것은 값이 일치해야하는 두 개의 동일한 필드를 만드는 특수 필드 "그룹"입니다. 구문은 다음과 같습니다.

use Symfony\Component\Form\Extension\Core\Type\RepeatedType; 
use Symfony\Component\Form\Extension\Core\Type\PasswordType; 

// ...  
$builder->add('password', RepeatedType::class, array( 
   'type' => PasswordType::class, 
   'invalid_message' => 'The password fields must match.', 
   'options' => array('attr' => array('class' => 'password-field')), 
   'required' => true, 
   'first_options'  => array('label' => 'Password'), 
   'second_options' => array('label' => 'Repeat Password'), 
));

주로 사용자의 비밀번호 나 이메일을 확인하는 데 사용됩니다.

ButtonType

클릭 가능한 간단한 버튼. 구문은 다음과 같습니다.

use Symfony\Component\Form\Extension\Core\Type\ButtonType; 
// ...  
$builder->add('save', ButtonType::class, array(
   'attr' => array('class' => 'save'), 
));

재설정 유형

모든 필드를 초기 값으로 재설정하는 버튼입니다. 구문은 다음과 같습니다.

use Symfony\Component\Form\Extension\Core\Type\ResetType; 
// ...  
$builder->add('save', ResetType::class, array( 
   'attr' => array('class' => 'save'), 
));

ChoiceType

다목적 필드는 사용자가 하나 이상의 옵션을 "선택"할 수 있도록하는 데 사용됩니다. 선택 태그, 라디오 버튼 또는 확인란으로 렌더링 할 수 있습니다. 구문은 다음과 같습니다.

use Symfony\Component\Form\Extension\Core\Type\ChoiceType; 
// ...  
$builder->add(‘gender’, ChoiceType::class, array( 
   'choices'  => array( 
      ‘Male’ => true, 
      ‘Female’ => false, 
   ), 
));

제출 유형

제출 버튼은 양식 데이터를 제출하는 데 사용됩니다. 구문은 다음과 같습니다.

use Symfony\Component\Form\Extension\Core\Type\SubmitType; 
// ...  
$builder->add('save', SubmitType::class, array( 
   'attr' => array('class' => 'save'), 
))

양식 도우미 기능

양식 도우미 함수는 템플릿에서 양식을 쉽게 만드는 데 사용되는 나뭇 가지 함수입니다.

form_start

유효한 작업, 경로 또는 URL을 가리키는 HTML 양식 태그를 반환합니다. 구문은 다음과 같습니다.

{{ form_start(form, {'attr': {'id': 'form_person_edit'}}) }}

form_end

form_start를 사용하여 만든 HTML 양식 태그를 닫습니다. 구문은 다음과 같습니다.

{{ form_end(form) }}

텍스트 영역

선택적으로 인라인 리치 텍스트 자바 스크립트 편집기로 래핑 된 textarea 태그를 반환합니다.

체크 박스

type =“checkbox”인 XHTML 호환 입력 태그를 반환합니다. 구문은 다음과 같습니다.

echo checkbox_tag('choice[]', 1);  
echo checkbox_tag('choice[]', 2);  
echo checkbox_tag('choice[]', 3);  
echo checkbox_tag('choice[]', 4);

input_password_tag

유형이 "password"인 XHTML 호환 입력 태그를 반환합니다. 구문은 다음과 같습니다.

echo input_password_tag('password');  
echo input_password_tag('password_confirm');

입력 _ 태그

유형이 "text"인 XHTML 호환 입력 태그를 반환합니다. 구문은 다음과 같습니다.

echo input_tag('name');

상표

지정된 매개 변수가있는 레이블 태그를 반환합니다.

라디오 버튼

유형이 "radio"인 XHTML 호환 입력 태그를 반환합니다. 구문은 다음과 같습니다.

echo ' Yes '.radiobutton_tag(‘true’, 1);  
echo ' No '.radiobutton_tag(‘false’, 0);

reset_tag

유형이 "reset"인 XHTML 호환 입력 태그를 반환합니다. 구문은 다음과 같습니다.

echo reset_tag('Start Over');

고르다

전 세계의 모든 국가로 채워진 선택 태그를 반환합니다. 구문은 다음과 같습니다.

echo select_tag(
   'url', options_for_select($url_list), 
   array('onChange' => 'Javascript:this.form.submit();'));

제출

유형이 "제출"인 XHTML 호환 입력 태그를 반환합니다. 구문은 다음과 같습니다.

echo submit_tag('Update Record');

다음 섹션에서는 양식 필드를 사용하여 양식을 만드는 방법을 배웁니다.

학생 양식 신청서

Symfony 양식 필드를 사용하여 간단한 학생 세부 정보 양식을 만들어 보겠습니다. 이렇게하려면 다음 단계를 따라야합니다.

1 단계 : Symfony 애플리케이션 생성

Symfony 애플리케이션을 만듭니다. formsample, 다음 명령을 사용합니다.

symfony new formsample

엔티티는 일반적으로 "src / AppBundle / Entity /"디렉토리 아래에 생성됩니다.

2 단계 : 엔티티 생성

"src / AppBundle / Entity /"디렉토리 아래에 "StudentForm.php"파일을 만듭니다. 파일에 다음 변경 사항을 추가하십시오.

StudentForm.php

<?php 
namespace AppBundle\Entity;  

class StudentForm {    
   private $studentName; 
   private $studentId; 
   public $password; 
   private $address; 
   public $joined; 
   public $gender; 
   private $email; 
   private $marks; 
   public $sports;  
   
   public function getStudentName() { 
      return $this->studentName; 
   }  
   public function setStudentName($studentName) { 
      $this->studentName = $studentName; 
   }  
   public function getStudentId() { 
      return $this->studentId; 
   }  
   public function setStudentId($studentid) { 
      $this->studentid = $studentid; 
   }
   public function getAddress() { 
      return $this->address; 
   }  
   public function setAddress($address) { 
      $this->address = $address; 
   }  
   public function getEmail() { 
      return $this->email; 
   }  
   public function setEmail($email) { 
      $this->email = $email; 
   }  
   public function getMarks() { 
      return $this->marks; 
   }  
   public function setMarks($marks) { 
      $this->marks = $marks; 
   } 
}

3 단계 : StudentController 추가

“src / AppBundle / Controller”디렉토리로 이동하여“StudentController.php”파일을 생성하고 다음 코드를 추가합니다.

StudentController.php

<?php  
namespace AppBundle\Controller;  

use AppBundle\Entity\StudentForm; 
use AppBundle\Form\FormValidationType; 

use Symfony\Bundle\FrameworkBundle\Controller\Controller; 
use Symfony\Component\HttpFoundation\Request; 
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route; 

use Symfony\Component\HttpFoundation\Response; 
use Symfony\Component\Form\Extension\Core\Type\TextType; 
use Symfony\Component\Form\Extension\Core\Type\DateType; 
use Symfony\Component\Form\Extension\Core\Type\SubmitType; 
use Symfony\Component\Form\Extension\Core\Type\ChoiceType; 
use Symfony\Component\Form\Extension\Core\Type\PasswordType; 
use Symfony\Component\Form\Extension\Core\Type\RangeType; 
use Symfony\Component\Form\Extension\Core\Type\EmailType; 
use Symfony\Component\Form\Extension\Core\Type\CheckboxType; 
use Symfony\Component\Form\Extension\Core\Type\ButtonType; 
use Symfony\Component\Form\Extension\Core\Type\TextareaType; 
use Symfony\Component\Form\Extension\Core\Type\PercentType; 
use Symfony\Component\Form\Extension\Core\Type\RepeatedType;  

class StudentController extends Controller {    
   /** 
      * @Route("/student/new") 
   */ 
   public function newAction(Request $request) {  
      $stud = new StudentForm(); 
      $form = $this->createFormBuilder($stud) 
         ->add('studentName', TextType::class)
         ->add('studentId', TextType::class) 
         ->add('password', RepeatedType::class, array( 
            'type' => PasswordType::class, 
            'invalid_message' => 'The password fields 
            must match.', 'options' => array('attr' => array('class' => 'password-field')), 
            'required' => true, 'first_options'  => array('label' => 'Password'), 
            'second_options' => array('label' => 'Re-enter'), 
         )) 
         
         ->add('address', TextareaType::class) 
         ->add('joined', DateType::class, array( 
               'widget' => 'choice', 
         )) 
            
         ->add('gender', ChoiceType::class, array( 
            'choices'  => array( 
               'Male' => true, 
               'Female' => false, 
            ), 
         )) 
         
         ->add('email', EmailType::class) 
         ->add('marks', PercentType::class) 
         ->add('sports', CheckboxType::class, array( 
            'label'    => 'Are you interested in sports?', 'required' => false, 
         )) 
         
         ->add('save', SubmitType::class, array('label' => 'Submit')) 
         ->getForm();  
         return $this->render('student/new.html.twig', array( 
            'form' => $form->createView(), 
         )); 
   } 
}

4 단계 : 뷰 렌더링

"app / Resources / views / student /"디렉토리로 이동하여 "new.html.twig"파일을 만들고 다음 변경 사항을 추가합니다.

{% extends 'base.html.twig' %} 
{% block stylesheets %} 
<style> 
   #simpleform { 
      width:600px; 
      border:2px solid grey; 
      padding:14px; 
   }  
   #simpleform label { 
      font-size:14px; 
      float:left; 
      width:300px; 
      text-align:right; 
      display:block; 
   }  
   #simpleform span { 
      font-size:11px; 
      color:grey; 
      width:100px; 
      text-align:right; 
      display:block; 
   }  
   #simpleform input { 
      border:1px solid grey; 
      font-family:verdana; 
      font-size:14px;
      color:light blue; 
      height:24px; 
      width:250px; 
      margin: 0 0 10px 10px; 
   }  
   #simpleform textarea { 
      border:1px solid grey; 
      font-family:verdana; 
      font-size:14px; 
      color:light blue; 
      height:120px; 
      width:250px; 
      margin: 0 0 20px 10px; 
   }  
   #simpleform select { 
      margin: 0 0 20px 10px; 
   }  
   #simpleform button { 
      clear:both; 
      margin-left:250px; 
      background: grey; 
      color:#FFFFFF; 
      border:solid 1px #666666; 
      font-size:16px; 
   } 
</style> 

{% endblock %}  
   {% block body %} 
   <h3>Student details:</h3> 
   <div id="simpleform"> 
      {{ form_start(form) }} 
      {{ form_widget(form) }} 
      {{ form_end(form) }} 
   </div> 
{% endblock %}

이제“http : // localhost : 8000 / student / new”URL을 요청하면 다음과 같은 결과가 생성됩니다.

결과