सिम्फनी - फॉर्म

आसानी से और सुरक्षित रूप से HTML रूपों को संभालने के लिए सिम्फनी विभिन्न इन-बिल्ट टैग प्रदान करती है। सिम्फनी का फॉर्म घटक निर्माण और सत्यापन प्रक्रिया करता है। यह मॉडल और व्यू लेयर को जोड़ता है। यह पूर्व-परिभाषित मॉडल से पूर्ण HTML प्रारूप बनाने के लिए फ़ॉर्म तत्वों का एक सेट प्रदान करता है। यह अध्याय रूपों के बारे में विस्तार से बताता है।

फॉर्म फील्ड्स

सिम्फनी फ्रेमवर्क एपीआई बड़े प्रकार के क्षेत्र का समर्थन करता है। आइए प्रत्येक क्षेत्र प्रकार के बारे में विस्तार से जाने।

FormType

इसका उपयोग सिम्फनी ढांचे में एक रूप उत्पन्न करने के लिए किया जाता है। इसका सिंटैक्स इस प्रकार है -

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 method का उपयोग किया जाता हैadd फार्म के अंदर इनपुट तत्व। title छात्र शीर्षक संपत्ति को संदर्भित करता है। TextType::classhtml टेक्स्ट फील्ड को संदर्भित करता है। Symfony सभी html तत्वों के लिए कक्षाएं प्रदान करता है।

पाठ्य प्रकार

TextType फ़ील्ड सबसे बुनियादी इनपुट टेक्स्ट फ़ील्ड का प्रतिनिधित्व करता है। इसका सिंटैक्स इस प्रकार है -

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

यहाँ, नाम एक इकाई के साथ मैप किया गया है।

TextareaType

एक textarea 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

पासवर्ड टाइप फ़ील्ड एक इनपुट पासवर्ड टेक्स्ट बॉक्स प्रस्तुत करता है। इसका सिंटैक्स इस प्रकार है -

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 - टाइप टेक्स्ट (महीने, दिन, वर्ष) के तीन फ़ील्ड इनपुट रेंडर करें।

  • 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', 
));

ध्यान दें कि, रेडियो बटन को अनियंत्रित नहीं किया जा सकता है, केवल तभी परिवर्तन होता है जब उसी नाम वाले दूसरे रेडियो बटन को चेक किया जाता है।

RepeatedType

यह एक विशेष फ़ील्ड "समूह" है, जो दो समान फ़ील्ड बनाता है जिनके मूल्यों का मिलान होना चाहिए। इसका सिंटैक्स इस प्रकार है -

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'), 
));

ResetType

एक बटन जो सभी क्षेत्रों को अपने प्रारंभिक मूल्यों पर रीसेट करता है। इसका सिंटैक्स इस प्रकार है -

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, 
   ), 
));

SubmitType

फॉर्म-डेटा जमा करने के लिए सबमिट बटन का उपयोग किया जाता है। इसका सिंटैक्स इस प्रकार है -

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

फॉर्म हेल्पर फंक्शन

फॉर्म हेल्पर फ़ंक्शंस ट्विग फ़ंक्शंस हैं, जिनका उपयोग टेम्प्लेट में आसानी से फ़ॉर्म बनाने के लिए किया जाता है।

form_start

एक HTML फॉर्म टैग लौटाता है जो एक मान्य कार्रवाई, मार्ग या URL की ओर इशारा करता है। इसका सिंटैक्स इस प्रकार है -

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

form_end

Form_start का उपयोग करके बनाए गए HTML फॉर्म टैग को बंद कर देता है। इसका सिंटैक्स इस प्रकार है -

{{ form_end(form) }}

पाठ क्षेत्र

वैकल्पिक रूप से इनलाइन रिच-टेक्स्ट जावास्क्रिप्ट संपादक के साथ लिपटे हुए, एक टेक्सैरिया टैग देता है।

चेक बॉक्स

प्रकार = "चेकबॉक्स" के साथ एक एक्सएचटीएमएल अनुरूप इनपुट टैग देता है। इसका सिंटैक्स इस प्रकार है -

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

input_password_tag

प्रकार = "पासवर्ड" के साथ एक XHTML अनुरूप इनपुट टैग देता है। इसका सिंटैक्स इस प्रकार है -

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

input_tag

प्रकार = "पाठ" के साथ एक XHTML अनुरूप इनपुट टैग देता है। इसका सिंटैक्स इस प्रकार है -

echo input_tag('name');

लेबल

निर्दिष्ट पैरामीटर के साथ एक लेबल टैग देता है।

रेडियो बटन

प्रकार = "रेडियो" के साथ एक XHTML अनुरूप इनपुट टैग देता है। इसका सिंटैक्स इस प्रकार है -

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

reset_tag

प्रकार = "रीसेट" के साथ एक 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');

अगले भाग में, हम सीखेंगे कि फॉर्म फील्ड का उपयोग करके फॉर्म कैसे बनाएं।

छात्र फॉर्म आवेदन

आइए सिम्फनी फॉर्म फ़ील्ड का उपयोग करके एक सरल छात्र विवरण बनाएं। ऐसा करने के लिए, हमें निम्नलिखित चरणों का पालन करना चाहिए -

चरण 1: एक सिम्फनी एप्लिकेशन बनाएं

एक सिम्फनी एप्लिकेशन बनाएं, 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: एक छात्र नियंत्रक जोड़ें

निर्देशिका "src / AppBundle / नियंत्रक" पर जाएं, "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: दृश्य प्रस्तुत करना

निर्देशिका "एप्लिकेशन / संसाधन / विचार / छात्र /" पर जाएं, "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 %}

अब url, "http: // localhost: 8000 / student / new" का अनुरोध करें और यह निम्नलिखित परिणाम उत्पन्न करता है।

परिणाम