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