FuelPHP - การเขียนโปรแกรมแบบฟอร์ม

FuelPHP มีสามคลาส Form Fieldset,, และ Inputเพื่อดำเนินการเขียนโปรแกรมแบบฟอร์ม

  • Form คลาสมีตัวเลือกในการสร้างองค์ประกอบของฟอร์ม HTML ทั้งหมด

  • Fieldset คลาสมีตัวเลือกในการสร้างองค์ประกอบ html ผ่านวิธีการระดับที่สูงขึ้นรวมโมเดลและการตรวจสอบความถูกต้อง

  • Input คลาสมีตัวเลือกในการแยกวิเคราะห์ข้อมูลที่ส่งผ่านรูปแบบ html ตลอดจนพารามิเตอร์ http ตัวแปรเซิร์ฟเวอร์และตัวแทนผู้ใช้

ในบทนี้ให้เราเรียนรู้ Form programming ใน FuelPHP

แบบฟอร์ม

ตามที่กล่าวไว้ก่อนหน้านี้คลาส Form มีวิธีการสร้างองค์ประกอบของฟอร์ม 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;'));

องค์ประกอบฉลาก

labelสร้างองค์ประกอบฉลาก html มีสามพารามิเตอร์ต่อไปนี้

  • $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 คล้ายกับวิธีการป้อนข้อมูลยกเว้นจะตั้งค่าประเภทขององค์ประกอบอินพุตเป็นไฟล์

textarea

textareaสร้างองค์ประกอบ html textarea มีสามพารามิเตอร์ต่อไปนี้

  • $field - ชื่อขององค์ประกอบ textarea

  • $value - ค่าขององค์ประกอบ textarea

  • $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 คล้ายกับวิธีการป้อนข้อมูลยกเว้นจะกำหนดประเภทขององค์ประกอบอินพุตที่จะส่ง

ปุ่ม

buttonสร้างองค์ประกอบปุ่ม html มีสามพารามิเตอร์ต่อไปนี้

  • $field - ชื่อขององค์ประกอบปุ่ม

  • $value - ค่าขององค์ประกอบปุ่ม

  • $attributes - คุณลักษณะขององค์ประกอบปุ่มเป็นอาร์เรย์

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

รีเซ็ต

reset คล้ายกับวิธีการป้อนข้อมูลยกเว้นจะตั้งค่าประเภทขององค์ประกอบอินพุตที่จะรีเซ็ต

fieldset_open

fieldset_open สร้างชุดฟิลด์ html และองค์ประกอบตำนาน มีสองพารามิเตอร์ต่อไปนี้ -

  • attributes - คุณลักษณะขององค์ประกอบ fieldset เป็นอาร์เรย์

  • 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

fieldset_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

is_ajaxคืนค่าจริงหากมีการร้องขอผ่าน AJAX

echo Input::is_ajax() // return false

มาตรการ

protocol ส่งคืนโปรโตคอล HTTP ที่ใช้ในคำขอ

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

ip

ip ส่งคืนที่อยู่ IP ที่ใช้ในการร้องขอ

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

real_ip

real_ip พยายามที่จะส่งคืนที่อยู่ 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

user_agentส่งคืนตัวแทนผู้ใช้จากตัวแปร $ _SERVER เป็นวิธีทางลัดเพื่อรับตัวแทนผู้ใช้ http ของคำขอปัจจุบัน

query_string

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'

ตัวอย่างการทำงาน

มาสร้างแบบฟอร์มง่ายๆเพื่อเพิ่มพนักงานใหม่โดยใช้ Form และ Input class

สร้างแบบฟอร์ม

สร้างการกระทำใหม่ get_add ในตัวควบคุมพนักงานดังนี้

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

ตอนนี้เพิ่มมุมมองสำหรับการดำเนินการเชื้อเพลิง / app / มุมมอง / พนักงาน / 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เพื่อออกแบบแบบฟอร์ม FuelPHP ให้การสนับสนุนอย่างเต็มที่สำหรับส่วนประกอบ bootstrap ตอนนี้ขอหน้า http: // localhost: 8080 / workers / add จะแสดงแบบฟอร์มต่อไปนี้

แบบฟอร์มกระบวนการ

สร้างการดำเนินการใหม่post_addเพื่อประมวลผลฟอร์มและเพิ่มข้อมูลพนักงานที่ผู้ใช้ป้อนลงในฐานข้อมูลในตัวควบคุมพนักงานดังนี้

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

ที่นี่เราถูกเปลี่ยนเส้นทางไปยังหน้ารายชื่อพนักงานเมื่อผู้ใช้ป้อนข้อมูลจะถูกบันทึกลงในฐานข้อมูล ต่อไปเราจะสร้างหน้ารายชื่อพนักงาน

รายชื่อพนักงาน

สร้างการดำเนินการใหม่ action_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ป้อนข้อมูลพนักงานตามที่แสดงในภาพหน้าจอต่อไปนี้และส่งแบบฟอร์ม

จากนั้นจะแสดงพนักงานทั้งหมด (รวมถึงพนักงานที่เพิ่งเพิ่มใหม่) ที่มีอยู่ในฐานข้อมูลดังนี้ -