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

FuelPHP तीन वर्ग प्रदान करता है, Form Fieldset,, तथा Input,, फार्म प्रोग्रामिंग करने के लिए।

  • Form क्लास सभी HTML फॉर्म एलिमेंट्स बनाने का विकल्प प्रदान करता है।

  • Fieldset वर्ग उच्च स्तरीय विधियों के माध्यम से HTML तत्व बनाने का एक विकल्प प्रदान करता है, मॉडल और मान्यता को एकीकृत करता है।

  • Input कक्षा HTML फॉर्म के साथ-साथ http पैरामीटर, सर्वर चर और उपयोगकर्ता एजेंटों के माध्यम से प्रस्तुत डेटा को पार्स करने का विकल्प प्रदान करता है।

इस अध्याय में, हम सीखते हैं Form programming फ्यूलपीपी में।

प्रपत्र

जैसा कि पहले चर्चा की गई थी, फॉर्म क्लास html फॉर्म एलिमेंट्स बनाने के तरीके प्रदान करता है और महत्वपूर्ण तरीके इस प्रकार हैं -

खुला हुआ()

open()एक नया रूप बनाने के लिए उपयोग किया जाता है। यह निम्नलिखित दो पैरामीटर प्रदान करता है -

  • $attributes - सरणी के रूप में प्रपत्र टैग की विशेषताएँ या स्ट्रिंग के रूप में केवल क्रिया URL।

  • $hidden - छिपे हुए क्षेत्र के नाम और उनके मूल्यों की सरणी।

echo Form::open('/employee/add'); 
echo Form::open(array('action' => '/employee/add', 'method' => 'post'));

बंद करे()

close() बस फॉर्म को बंद कर देता है।

echo Form::close();

इनपुट ()

input()HTML इनपुट तत्व बनाता है। इसके निम्नलिखित तीन मापदंड हैं,

  • $field - इनपुट तत्व का नाम

  • $value - इनपुट तत्व का मूल्य

  • $attributes - सरणी के रूप में इनपुट तत्व की विशेषताएं

echo Form::input('name', 'jon', array('style' => 'border: 20px;'));

लेबल तत्व

labelhtml लेबल तत्व बनाता है। इसके निम्नलिखित तीन मापदंड हैं,

  • $label - दिखाने के लिए लेबल

  • $id - संबद्ध प्रपत्र एलिमेंट आईडी

  • $attributes - सरणी के रूप में लेबल तत्व की विशेषताएं

echo Form::label('Employee Name', 'employee_name');

छिपा हुआ

hidden इनपुट विधि के समान है, इसके अलावा यह इनपुट तत्व के प्रकार को छिपाता है।

कुंजिका

password यह इनपुट विधि के समान है, सिवाय इसके कि यह इनपुट तत्व के प्रकार को पासवर्ड पर सेट करता है।

रेडियो

radioइनपुट विधि के समान है, सिवाय इसके कि यह इनपुट तत्व के प्रकार को रेडियो पर सेट करता है। इसके निम्नलिखित चार मापदंड हैं,

  • $field - इनपुट तत्व का नाम

  • $value - इनपुट तत्व का मूल्य

  • $checked - आइटम चेक किया गया है या नहीं (सही / गलत)

  • $attributes - सरणी के रूप में इनपुट तत्व की विशेषताएं

echo Form::label('Male', 'gender'); 
echo Form::radio('gender', 'Male', true); 
echo Form::label('Female', 'gender'); 
echo Form::radio('gender', 'Female');

चेक बॉक्स

checkboxयह इनपुट विधि के समान है, सिवाय इसके इनपुट इनपुट के प्रकार को चेकबॉक्स पर सेट करता है। इसके निम्नलिखित चार मापदंड हैं,

  • $field - इनपुट तत्व का नाम

  • $value - इनपुट तत्व का मूल्य

  • $checked - आइटम चेक किया गया है या नहीं (सही / गलत)

  • $attributes - सरणी के रूप में इनपुट तत्व की विशेषताएं

echo Form::label('Male', 'gender'); 
echo Form::checkbox('gender', 'Male', true);
echo Form::label('Female', 'gender'); 
echo Form::checkbox('gender', 'Female');

फ़ाइल

file इनपुट विधि के समान है, सिवाय इसके कि फ़ाइल में इनपुट तत्व का प्रकार सेट किया जाए।

पाठ क्षेत्र

textareahtml textarea तत्व बनाता है। इसके निम्नलिखित तीन मापदंड हैं,

  • $field - टेक्सारिया तत्व का नाम

  • $value - टेक्सटेरिया तत्व का मूल्य

  • $attributes - सरणी के रूप में textarea तत्व की विशेषताएं

echo Form::textarea ('description', 'original data (value)', array ('rows' => 6, 
      'cols' => 8));

चुनते हैं

selectएक HTML चुनिंदा तत्व बनाता है। इसके निम्नलिखित चार मापदंड हैं -

  • $field - चुनिंदा तत्व का नाम

  • $values - प्रारंभिक चयन मान

  • $options- सरणी के रूप में विकल्प। विकल्प नेस्टेड सरणी का उपयोग करके समूहीकृत किया जा सकता है

  • $attributes - सरणी के रूप में इनपुट तत्व की विशेषताएं

echo Form::select ( 
   'country',  
   'none',  
   array ( 
      'none'  => 'None', 
      'asia'  => array ( 
         'in' > 'India', 
         'cn' => 'China' 
      ), 
      
      'us' => 'United States' 
   ) 
);

प्रस्तुत

submit इनपुट विधि के समान है, सिवाय इसके कि यह इनपुट तत्व के प्रकार को प्रस्तुत करता है।

बटन

buttonhtml बटन तत्व बनाता है। इसके निम्नलिखित तीन मापदंड हैं,

  • $field - बटन तत्व का नाम

  • $value - बटन तत्व का मूल्य

  • $attributes - सरणी के रूप में बटन तत्व की विशेषताएं

echo Form::button('emp_submit', 'Submit');

रीसेट

reset इनपुट विधि के समान है, इसके अलावा यह रीसेट करने के लिए इनपुट तत्व के प्रकार को सेट करता है।

fieldset_open

fieldet_open html फ़ील्ड सेट और किंवदंती तत्व बनाता है। इसके निम्नलिखित दो मापदंड हैं -

  • attributes - सरणी के रूप में फ़ील्डसेट तत्व की विशेषताएं

  • legend - बनाने के लिए किंवदंती का नाम

// returns <fieldset class = "example-class" id = "example-id">
<legend>
   Custom Legend
</legend> 

echo Form::fieldset_open (array (
   'class'  => 'example-class', 
   'id'     => 'exampleid', 
   'legend' => 'Custom Legend'
));

fieldset_close

fieldet_close HTML फ़ील्ड सेट क्लोज़ टैग बनाता है।

// returns </fieldset> 
echo Form::fieldset_close();

इनपुट क्लास

इनपुट क्लास फॉर्म विवरण के साथ सभी अनुरोध डेटा को पढ़ने के लिए तरीके प्रदान करता है। कुछ महत्वपूर्ण तरीके इस प्रकार हैं -

उरी

uri अनुरोध का वर्तमान URI लौटाता है

// request: http://localhost:8080/employee/welcome  
echo Input::uri(); // return /employee/welcome

तरीका

method अनुरोध में प्रयुक्त HTTP विधि लौटाता है

echo Input::method() // "POST"

प्राप्त

get$ _GET चर पढ़ने में सक्षम बनाता है। इसके निम्नलिखित दो मापदंड हैं,

  • $index - $ _GET सरणी का सूचकांक

  • $default - डिफ़ॉल्ट मान, यदि इंडेक्स नहीं मिला।

echo Input::get('age', '20'); // returns $_GET['age']

पद

post$ _POST चर पढ़ने में सक्षम बनाता है। इसके निम्नलिखित दो मापदंड हैं,

  • $index - $ _POST सरणी का सूचकांक

  • $default - डिफ़ॉल्ट मान, यदि इंडेक्स नहीं मिला

echo Input::get('age', '20'); // returns $_POST['age']

परम

param$ _GET, $ _POST, $ _PUT, या $ _DELETE चर से आइटम लाने में सक्षम बनाता है। इसके निम्नलिखित दो मापदंड हैं,

  • $index - सरणी का सूचकांक

  • $default - डिफ़ॉल्ट मान, यदि इंडेक्स नहीं मिला

यदि कोई पैरामीटर निर्दिष्ट नहीं है, तो यह सभी आइटम वापस कर देगा।

echo Input::param('age', '20'); // returns $_POST['age']

फ़ाइल

file$ _FILE चर पढ़ने में सक्षम बनाता है। इसके निम्नलिखित दो मापदंड हैं,

  • $index - $ _POST सरणी का सूचकांक

  • $default - डिफ़ॉल्ट मान, यदि इंडेक्स नहीं मिला

echo Input::file();

is_ajax

यदि AJAX के माध्यम से अनुरोध किया जाता है, तो is_ajax सही रहता है।

echo Input::is_ajax() // return false

मसविदा बनाना

protocol अनुरोध में प्रयुक्त HTTP प्रोटोकॉल लौटाता है।

echo Input::protocol() // returns "HTTP"

आईपी

ip वह आईपी पता लौटाता है जिसके माध्यम से अनुरोध किया जाता है।

echo Input::ip() // returns "84.45.34.24" (Public IP Address)

real_ip

real_ip वास्तविक आईपी पता (यदि क्लाइंट प्रॉक्सी के पीछे है) वापस करने की कोशिश करता है जिसके माध्यम से अनुरोध किया जाता है।

echo Input::real_ip() // returns "10.76.12.1" (local private IP Address)

सर्वर

server$ _SERVER चर पढ़ने में सक्षम बनाता है। इसके निम्नलिखित दो मापदंड हैं,

  • $index - $ _POST सरणी का सूचकांक

  • $default - डिफ़ॉल्ट मान, यदि इंडेक्स नहीं मिला।

echo Input::server('HTTP_HOST'); // returns localhost:8080

रेफरर

referrer$ _SERVER चर से रेफरल लौटाता है। वर्तमान अनुरोध के http रेफ़रर को प्राप्त करने के लिए यह एक शॉर्टकट विधि है।

उपभोक्ता अभिकर्ता

user_agent$ _SERVER चर से उपयोगकर्ता एजेंट लौटाता है। वर्तमान अनुरोध के http उपयोगकर्ता एजेंट को प्राप्त करने के लिए यह एक शॉर्टकट विधि है।

क्वेरी स्ट्रिंग

query_string$ _SERVER चर से क्वेरी स्ट्रिंग लौटाता है। यह वर्तमान अनुरोध के क्वेरी स्ट्रिंग को प्राप्त करने के लिए एक शॉर्टकट विधि है।

हेडर

headersविशिष्ट या सभी शीर्ष लेख लौटाएं। इसके निम्नलिखित दो मापदंड हैं -

  • $index - HTTP हेडर का नाम

  • $default - डिफ़ॉल्ट मान, यदि इंडेक्स नहीं मिला।

echo Input::headers('Content-Type'); // returns "text/html"

एक्सटेंशन

extension वर्तमान अनुरोध का URI एक्सटेंशन लौटाता है।

// Example URL: http://localhost/test/ 
echo Input::extension();  // NULL  

// Example URL: http://localhost/test.html 
echo Input::extension();  // 'html'

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

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

फार्म बनाएं

नई कार्रवाई बनाएं, get_add कर्मचारी नियंत्रक में निम्नानुसार है।

public function get_add() { 
   return Response::forge(View::forge('employee/add')); 
}

अब, क्रिया, ईंधन / ऐप / विचार / कर्मचारी / add.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'); ?> 
   </head>
   
   <body> 
      <div class = "container"> 
         <?php 
            echo Form::open(array('action' => 'employee/add', 'method' => 'post')); 
         ?>  
         
         <div class = "form-group"> 
            <?php 
               echo Form::label('Employee name:', 'name'); 
               echo Form::input('name', '', array('class' => 'form-control')); 
            ?> 
         </div> 
         
         <div class = "form-group"> 
            <?php 
               echo Form::label('Employee age:', 'age'); 
               echo Form::input('age', '', array('class' => 'form-control')); 
            ?> 
         </div> 
         
         <?php echo Form::button('frmbutton', 'Submit', array(
            'class' => 'btn btn-default')); 
         ?> 
         
         <?php 
            echo Form::close(); 
         ?> 
      </div> 
   </body> 
   
</html>

यहां, हमने उपयोग किया है bootstrapफार्म को डिजाइन करने के लिए। फ्यूलफेप बूटस्ट्रैप घटकों के लिए पूर्ण समर्थन प्रदान करता है। अब, पृष्ठ का अनुरोध करते हुए, http: // localhost: 8080 / कर्मचारी / जोड़ निम्नलिखित रूप दिखाएगा।

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

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

public function post_add() { 
   $name = Input::post('name'); 
   $age = Input::post('age'); 
   $model = new model_employee(); 
   $model->name = $name; 
   $model->age = $age; 
   $model->save();  
   Response::redirect('employee/list'); 
}

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

सूची कर्मचारी

डेटाबेस में कर्मचारी को सूचीबद्ध करने के लिए नई कार्रवाई, एक्शन_लिस्ट बनाएं।

public function action_list() { 
   $data = array(); 
   $data['emps'] = model_employee::find('all');
   return Response::forge(view::forge('employee/list', $data)); 
}

नया दृश्य बनाएं, fuel/app/views/employee/list उपरोक्त क्रिया के लिए निम्नानुसार है।

<ul> 
   <?php 
      foreach($emps as $emp) {  
   ?> 
   <li><?php echo $emp['name']; ?></li> 
   <?php 
   } 
   ?> 
</ul>

फॉर्म की जांच करें

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

फिर, यह डेटाबेस में उपलब्ध सभी कर्मचारियों (नव जोड़ा एक सहित) को निम्नानुसार दिखाता है -