- A login form
- A contact form
- A registration form
- A reservation form
- Dependencies
- File upload
- More rules
|
A meeting room reservation form
-
try clicking on the submit button without filling the form and then, as you fill the form, to see the
JavaScript validation in action
- for each example, notice how the PHP code of the form remains basically unchanged, despite the template variations
-
disable JavaScript to see the server-side validation in action
-
although in all my examples I use HTML output, you can switch to XHTML output by using the
doctye method
-
try the example in another browser and see that it works, out of the box. including IE6!
<?php
require 'path/to/Zebra_Form.php';
$form = new Zebra_Form('form');
$form->add('label', 'label_name', 'name', 'Your name:');
$obj = $form->add('text', 'name');
$obj->set_rule(array(
'required' => array('error', 'Name is required!')
));
$form->add('label', 'label_email', 'email', 'Your email address:');
$obj = $form->add('text', 'email');
$obj->set_rule(array(
'required' => array('error', 'Email is required!'),
'emails' => array('error', 'Email address seems to be invalid!'),
));
$form->add('label', 'label_department', 'department', 'Department:');
$obj = $form->add('select', 'department', '', array('other' => true));
$obj->add_options(array(
'Marketing',
'Operations',
'Customer Service',
'Human Resources',
'Sales Department',
'Accounting Department',
'Legal Department',
));
$obj->set_rule(array(
'required' => array('error', 'Department is required!')
));
$form->add('label', 'label_room', 'room', 'Which room would you like to reserve:');
$obj = $form->add('radios', 'room', array(
'A' => 'Room A',
'B' => 'Room B',
'C' => 'Room C',
));
$obj->set_rule(array(
'required' => array('error', 'Room selection is required!')
));
$form->add('label', 'label_extra', 'extra', 'Extra requirements:');
$obj = $form->add('checkboxes', 'extra[]', array(
'flipchard' => 'Flipchard and pens',
'plasma' => 'Plasma TV screen',
'beverages' => 'Coffee, tea and mineral water',
));
$form->add('label', 'label_date', 'date', 'Reservation date');
$date = $form->add('date', 'date');
$date->set_rule(array(
'required' => array('error', 'Date is required!'),
'date' => array('error', 'Date is invalid!'),
));
$date->format('M d, Y');
$form->add('note', 'note_date', 'date', 'Date format is M d, Y');
$form->add('label', 'label_time', 'time', 'Reservation time :');
$obj = $form->add('time', 'time', '', array(
'format' => 'hm',
'hours' => array(9, 10, 11, 12, 13, 14, 15, 16, 17),
'minutes' => array(0, 30),
));
$obj->set_rule(array(
'required' => array('error', 'Time is required!'),
));
$form->add('submit', 'btnsubmit', 'Submit');
if ($form->validate()) {
show_results();
} else
$form->render();
?>
In this example, the output is automatically generated by Zebra_Form's render method.
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>Zebra_Form Example</title>
<link rel="stylesheet" href="path/to/zebra_form.css">
</head>
<body>
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script>window.jQuery || document.write('<script src="path/to/jquery-1.9.1.min.js"><\/script>')</script>
<script src="path/to/zebra_form.js"></script>
</body>
</html>
|