फ्यूलफेप - एडवांस्ड फॉर्म प्रोग्रामिंग

FuelPHP Fieldset और Fieldset_Field वर्गों के माध्यम से एक उन्नत रूप प्रोग्रामिंग प्रदान करता है। Fieldsetप्रपत्र बनाने के लिए ऑब्जेक्ट-ओरिएंटेड तरीका प्रदान करता है। इसमें मॉडल्स का पूरा सपोर्ट है। इसमें क्लाइंट-साइड और सर्वर-साइड सत्यापन के लिए अंतर्निहित समर्थन है। एक पूर्ण रूप बनाने के लिए, उचित रूप और सत्यापन सेटिंग के साथ एक मॉडल बनाने के लिए पर्याप्त है। आइए हम फील्ड्स क्लास के बारे में जानें और इस अध्याय में इसका उपयोग करके फॉर्म कैसे बनाएं।

fieldset

फील्ड्स का एक संग्रह है Fieldset_Fieldवस्तुओं। Fieldset_Field मान्यताओं के साथ फॉर्म का व्यक्तिगत प्रवेश जैसे कि फर्स्टनेम, लास्टनाम आदि को परिभाषित करता है। फ़ील्ड्स फ़ील्ड में फ़ील्ड जोड़ने / संपादित करने / निकालने की विधियाँ हैं। इसमें एक मॉडल में परिभाषित क्षेत्रों की पहचान करने और दिए गए मॉडल से फ़ील्ड बनाने के विकल्प हैं।Fieldsetवास्तविक कार्य करने के लिए पृष्ठभूमि में फॉर्म और सत्यापन कक्षाओं का उपयोग करता है। आइए हम फील्ड्स क्लास के कुछ महत्वपूर्ण तरीकों को देखते हैं।

फोर्ज

forgeएक नया फील्डसेट उदाहरण बनाता है। इसके निम्नलिखित दो मापदंड हैं -

  • $name - क्षेत्र के लिए पहचानकर्ता

  • $config- कॉन्फ़िगरेशन सरणी। संभावित विकल्प हैं validation_instance और form_instance। validation_instance में Validation object हो सकते हैं और form_instance में Form Object हो सकते हैं।

$employee_form = Fieldset::forge('employee');

उदाहरण

instance पहचानकर्ता द्वारा पूर्व में बनाई गई फ़ील्ड फ़ील्ड को लौटाता है।

$employee_form = Fieldset::instance('employee');

get_name

फ़ील्डसेट उदाहरण की पहचानकर्ता हो जाता है।

$employee_form = Fieldset::forge('employee'); 
$name = $employee_form->get_name();

जोड़ना

addएक नया Fieldset_Field उदाहरण बनाता है और इसे वर्तमान फ़ील्डसेट में जोड़ता है। इसमें निम्नलिखित चार पैरामीटर हैं,

  • $name - मैदान का नाम

  • $label - क्षेत्र के लिए लेबल

  • $attributes - HTML टैग विशेषताएँ

  • $rules - सत्यापन नियम

$employee_field = $employee_form-> add (
   'employee_lastname', 
   'Lastname', 
   array ('class' => 'pretty_input')
);  

// with validation rules 
$employee_form->add ( 
   'email', 'E-mail', 
   array('type' => 'email', 'class' => 'pretty_input'), 
   array('required', 'valid_email') 
);

से पहले मिलाएं

add_before जोड़ने के समान है, इसके अलावा उस फ़ील्ड को निर्दिष्ट करने के लिए एक अतिरिक्त पैरामीटर है जिससे पहले नया बनाया गया फ़ील्ड जोड़ा जाएगा।

$employee_form->add_before (
   'employee_firstname', 
   'Firstname', 
   array ('class' => 'pretty_input'), 
   array(), 
   'employee_lastname'
);

हटाना

delete फ़ील्ड से निर्दिष्ट फ़ील्ड हटाता है।

$employee_form->delete('employee_firstname');

मैदान

field या तो सभी फ़ील्ड या फ़ील्ड से निर्दिष्ट एक हो जाता है।

$fields = $employee_form->field(); 
$lastname_field = $employee_form->field('employee_lastname');

बिल्ड

build$ इस के लिए उपनाम है-> फार्म () -> निर्माण () । प्रपत्र का HTML मार्कअप बनाता है।

$employee_form->build(Uri::create('employee/add'));

सक्षम

enable पहले से अक्षम किए गए फ़ील्ड को फिर से सक्षम करता है।

$employee_form->enable('employee_firstname');

अक्षम

disable फ़ील्ड में एक फ़ील्ड को बनाने से अक्षम करने की अनुमति देता है।

$employee_form->disable('employee_firstname');

प्रपत्र

form वर्तमान फ़ील्ड का प्रपत्र उदाहरण लौटाता है।

$form = employee_form->form();

add_model

add_model फ़ील्ड के मॉडल फ़ील्ड को जोड़ता है। इसके निम्नलिखित तीन मापदंड हैं,

  • $class - वर्ग का नाम

  • $instance - मूल्य के साथ खेतों को आबाद करने के लिए वर्ग का उदाहरण

  • $method- कक्षा में विधि का नाम। इस विधि का उपयोग खेतों को खेतों में जोड़ने के लिए किया जाता है। Orm \ Model में आवश्यक विधि है। डिफ़ॉल्ट विधि का नाम set_form_fields है।

$employee_form = Fieldset::forge('employee'); 
$employee_form->add_model('Model_Employee');

आबाद करना

populate मॉडल उदाहरण का उपयोग करके फ़ील्डसेट में फ़ील्ड का प्रारंभिक मान सेट करता है।

$emp = new Model_Employee(); 
$emp->name = "Jon"; 
$employee_form->populate($emp);

फिर से आबाद

repopulate यह आबादी के समान है, सिवाय इसके कि यह खेतों में खेतों को फिर से खोल देता है।

मान्यता

validation वर्तमान फ़ील्ड का सत्यापन उदाहरण मिलता है।

$validation = $employee_form->validation();

मान्य

$ इस के लिए उपनाम-> सत्यापन () -> मान्य ()।

input

$ इस के लिए उपनाम- सत्यापन () -> इनपुट ()।

error

इस $ के लिए उपनाम-> सत्यापन () -> त्रुटि ()।

show_errors

$ इस के लिए उपनाम-> सत्यापन () -> show_errors ()।

काम करने का उदाहरण

आइए फील्ड्स क्लास का उपयोग करके हमारे नमूना कर्मचारी आवेदन में नए कर्मचारी को जोड़ने के लिए एक उन्नत फ़ॉर्म बनाएं।

अद्यतन मॉडल

आवश्यक सत्यापन नियमों के साथ कर्मचारी मॉडल को अपडेट करें और निम्नानुसार एक सत्यापन पर्यवेक्षक जोड़ें।

<?php  
   class Model_Employee extends Orm\Model { 
      protected static $_connection = 'production'; 
      protected static $_table_name = 'employee'; 
      protected static $_primary_key = array('id'); 
      
      protected static $_properties = array ( 
         'id',  
         'name' => array ( 
            'data_type' => 'varchar',
            'label' => 'Employee Name', 
            'validation' => array ( 
               'required',  
               'min_length' => array(3),  
               'max_length' => array(80) 
            ), 
            'form' => array ( 
               'type' => 'text' 
            ), 
         ),  
         'age' => array ( 
            'data_type' => 'int', 
            'label' => 'Employee Age', 
            'validation' => array ( 
               'required',  
            ), 
            'form' => array ('type' => 'text' ), 
         ), 
      );  
      
      // Just add the Observer, and define the required event 
      protected static $_observers = array('Orm\\Observer_Validation' => array ( 
         'events' => array('before_save'))); 
   }

यहां, हमने नाम और आयु क्षेत्रों के सत्यापन नियमों को परिभाषित किया है और डेटाबेस में मॉडल को सहेजने से पहले सर्वर साइड सत्यापन करने के लिए एक नया पर्यवेक्षक जोड़ा है। समान सत्यापन नियम आवश्यक इनपुट सत्यापन विशेषताओं के साथ-साथ प्रपत्र में भी बनाएगा।

फॉर्म बनाएं

कर्मचारी नियंत्रक में नई क्रिया, action_advancedform बनाएँ।

public function action_advancedform() { 
   
   // create a new fieldset and add employee model
   $fieldset = Fieldset::forge('employee')->add_model('Model_Employee');  
   
   // get form from fieldset 
   $form = $fieldset->form();  
   
   // add submit button to the form 
   $form->add('Submit', '', array('type' => 'submit', 'value' => 'Submit'));  
   
   // build the form  and set the current page as action  
   $formHtml = $fieldset->build(Uri::create('employee/advancedform'));  
   
   // set form in data 
   $data = array(); 
   $data['form'] = $formHtml;  
   return Response::forge(View::forge('employee/advancedform', $data, false)); 
}

यहां, हमने फ़ील्डसेट का उपयोग करके फ़ॉर्म बनाया है और फ़ॉर्म को दृश्य पर भेजें। अगला, कार्रवाई के लिए दृश्य जोड़ें,fuel/app/views/employee/advancedform.php निम्नलिखित नुसार।

<!DOCTYPE html> 
<html lang = "en"> 
   
   <head> 
      <title>Employee :: add page</title> 
      <meta charset = "utf-8"> 
      <meta name = "viewport" content = "width = device-width, initial-scale = 1"> 
      <?php echo Asset::css('bootstrap.css'); ?> 
      
      <style>  
         table { 
            width: 90%; 
         }  
         table tr { 
            width: 90% 
         }
         table tr td { 
            width: 50% 
         }  
         input[type = text], select { 
            width: 100%; 
            padding: 12px 20px; 
            margin: 8px 0; 
            display: inline-block; 
            border: 1px solid #ccc; 
            border-radius: 4px; 
            box-sizing: border-box; 
         }  
         input[type = submit] { 
            width: 100%; 
            background-color: #3c3c3c; 
            color: white; 
            padding: 14px 20px; 
            margin: 8px 0; 
            border: none; 
            border-radius: 4px; 
            cursor: pointer; 
         }  
         div { 
            border-radius: 5px; 
            background-color: #f2f2f2; 
            padding: 20px; 
         } 
      </style> 
   </head> 
   
   <body> 
      <div class = "container"> 
         <?php
            if(isset($errors)) { 
               echo $errors; 
            } 
            echo $form; 
         ?> 
      </div> 
   </body> 
   
</html>

अब पृष्ठ का अनुरोध कर रहा हूं http://localhost:8080/employee/add निम्न प्रपत्र दिखाएगा।

प्रक्रिया प्रपत्र

प्रपत्र को संसाधित करने के लिए क्रिया विधि, action_advancedform अद्यतन करें और उपयोगकर्ता द्वारा दर्ज किए गए कर्मचारी डेटा को डेटाबेस में कर्मचारी नियंत्रक में जोड़ दें।

public function action_advancedform() { 
   
   // create a new fieldset and add employee model 
   $fieldset = Fieldset::forge('employee')->add_model('Model_Employee');  
   
   // get form from fieldset 
   $form = $fieldset->form();  
   
   // add submit button to the form 
   $form->add('Submit', '', array('type' => 'submit', 'value' => 'Submit')); 
   
   // build the form  and set the current page as action  
   $formHtml = $fieldset->build(Uri::create('employee/advancedform'));  
   
   if (Input::param() != array()) { 
      try { 
         $article = Model_Employee::forge(); 
         $article->name = Input::param('name'); 
         $article->url = Input::param('age'); 
         $article->save(); 
         Response::redirect('employee/list'); 
      
      } 
      catch (Orm\ValidationFailed $e) { 
         $view = View::forge('employee/advancedform'); 
         $view->set('form', $formHtml, false); 
         $view->set('errors', $e->getMessage(), false); 
      } 
   } 
   
   return Response::forge($view); 
}

यहां, उपयोगकर्ता सूची पृष्ठ पर हमें पुनः निर्देशित किया गया है, एक बार उपयोगकर्ता द्वारा दर्ज किया गया डेटा वैध हो जाता है और डेटाबेस में सहेज लिया जाता है। अन्यथा, हमें फिर से फॉर्म दिखाया जाएगा।

फॉर्म बनाएं

अब, URL का अनुरोध करें, http://localhost:8080/employee/addऔर कुछ कर्मचारी डेटा दर्ज करें और फॉर्म जमा करें। यदि डेटा प्रदान नहीं किया गया है, तो प्रपत्र उपयोगकर्ता को निम्न स्क्रीनशॉट में दिखाए अनुसार डेटा दर्ज करने के लिए संकेत देगा।

यदि उपयोगकर्ता क्लाइंट साइड सत्यापन को बायपास करता है, तो सर्वर फॉर्म को मान्य करेगा और निम्न स्क्रीनशॉट में दिखाए अनुसार एक त्रुटि दिखाएगा।

यदि डेटा क्लाइंट और सर्वर साइड सत्यापन पारित किया है, तो कर्मचारी डेटा डेटाबेस में सहेजा जाएगा और पेज सूची पृष्ठ पर पुनर्निर्देशित हो जाता है।