载入辅助函数
用下面的代码载入该辅助函数:
$this->load->helper(‘form’);
创建一个开始form标签,相对于你的配置文档中的基础URL。
允许你添加一些form属性和一些隐藏表单,并且他会基于你的 config.php 文件里设置的编码,自动生成 acceptcharset 这个属性。使用这个函数而不是直接硬编码HTML的主要的优势是使你的程序可以方便的转换,如果你的URL变化的话。
下面是一个例子:
echo form_open(‘email/send’);
上面的例子会创建一个form提交至你的基础URL加上”email/send” URI片段,像这样:
可以在第二个参数里传递一个关联数组来达到这一目的, 像这样:
$attributes = array('class' => 'email', 'id' => 'myform');
echo form_open('email/send', $attributes);
上面的例子会创建一个这样的form标签:
隐藏域可以使用数组加在第三个参数上,就像这样:
$hidden = array('username' => 'Joe', 'member_id' => '234');
echo form_open('email/send', '', $hidden);
上面的例子会创建一个这样的form标签和这些隐藏域:
这个函数和上面的form_open()函数完全一样,不同之处在于它多了一个multipart属性。如果你要制作一个上传文件
的表单,这个属性是必须的。
可以使你创建一个隐藏输入栏。你可以输入name和value来创建一个:
echo form_hidden('username', 'johndoe');
将产生:
type="hidden" name="username" value="johndoe" />
或者你也可以使用数组来联合创建它们:
$data = array(
'name' => 'John Doe',
'email' => '[email protected]',
'url' => 'http://example.com'
);
echo form_hidden($data);
将产生:
type="hidden" name="name" value="John Doe" />
type="hidden" name="email" value="[email protected]" />
type="hidden" name="url" value="http://example.com" />
可以使你创建一个标准输入栏。你可以在第一和第二个参数里输入name和value来创建一个:
echo form_input('username', 'johndoe');
或者你也可以用关联数组来添加你想加入的内容:
$data = array(
'name' => 'username',
'id' => 'username',
'value' => 'johndoe',
'maxlength' => '100',
'size' => '50',
'style' => 'width:50%',
);
echo form_input($data);
将产生:
type="text" name="username" id="username" value="johndoe" maxlength="100" size="50" style="width:50%" />
如果你想加入一些额外的内容,例如Javascript,你可以在第三个参数里输入字符串来创建它:
$js = 'onClick="some_function()"';
echo form_input('username', 'johndoe', $js);
form_password()
此函数除了是设置type为“password”外和上面的 form_input() 函数完全一样。
此函数与上面的 form_input() 函数几乎完全相同,唯一的区别是此函数所设置的 type 为 “file”,用来上传文件。
此函数与上面的 form_input() 函数几乎完全相同,唯一的区别是此函数所生成的是一个”textarea”。说明:上面的范
例中所指定的 “maxlength” 和 “size” 属性在这里变成了 “rows” 和 “cols”。
创建一个标准的下拉列表字段。第一个参数是字段名,第二个参数是一个包含各个选项的关联数组,第三个参数是你想
要设置为默认被选中的值。第三个参数也可以是一个包含多个项目的数组,CI 将为你创建多选下拉列表。例如:
$options = array(
'small' => 'Small Shirt',
2
'med' => 'Medium Shirt',
'large' => 'Large Shirt',
'xlarge' => 'Extra Large Shirt',
);
$shirts_on_sale = array('small', 'large');
echo form_dropdown('shirts', $options, 'large');
将会生成:
echo form_dropdown('shirts', $options, $shirts_on_sale);
将会生成:
如果你希望 开始标签包含一些额外的属性,例如 id 属性以及JavaScript,你可以将一个字符串作为第四个参
数传递过去:
$js = 'id="shirts" onChange="some_function();"';
echo form_dropdown('shirts', $options, 'large', $js);
如果$options参数是一个多维数组,form_dropdown() 函数将使用数组的键作为 label值生成一个 标
签。
该函数可以生成标准的复选列表。第一个参数给出表单项的名称;第二个参数用一个关联数组给出该表单项的全部可选
项列表;第三个参数规定哪几项是默认已选取的。这些参数的用法跟上面的form_dropdown()完全一样。当然,由于
是复选的,在处理传值的时候,我们要使用数组的语法。数组语法的例子:foo[]。
echo "fieldset content here
\n";
echo form_fieldset_close();
生成
<fieldset>
<legend>Address Informationlegend>
<p>form content herep>
fieldset>
与其它函数类似,在第二个参数你可以传递一个关联数组来添加你自己想要的自定义的属性。
$attributes = array('id' => 'address_info', 'class' => 'address_info');
echo form_fieldset('Address Information', $attributes);
echo "fieldset content here
\n";
echo form_fieldset_close();
生成
<fieldset id="address_info" class="address_info">
<legend>Address Informationlegend>
<p>form content herep>
fieldset>
form_fieldset_close()
生成一个结束的fieldset标签。唯一的优势是,使用该函数,你可以传递数据,这些数据会附加在这个标签的后面。例
如:
$string = "
会生成:
fieldset>
div>div>
作用是生成一个复选框。简单范例如下:
echo form_checkbox('newsletter', 'accept', TRUE);
将会生成:
type="checkbox" name="newsletter" value="accept" checked="checked" />
第三个参数为 TRUE/FALSE 布尔值,决定复选框是否被默认选中。
与其它表单辅助函数相似的是,你可以把包含了属性值的数组作为参数传递给本函数:
$data = array(
'name' => 'newsletter',
'id' => 'newsletter',
'value' => 'accept',
'checked' => TRUE,
'style' => 'margin:10px',
);
echo form_checkbox($data);
将会生成:
type="checkbox" name="newsletter" id="newsletter" value="accept" checked="checked" style="margin:10px" />
与其它函数相似的,如果你希望此标签包含额外的数据,例如JavaScript,你可以将一个字符串作为第四个参数传递过
去:
$js = 'onClick="some_function()"';
echo form_checkbox('newsletter', 'accept', TRUE, $js);
此函数与上面的 form_checkbox() 函数几乎完全相同,唯一的区别是此函数生成的是 “radio” 单选框。
帮助你生成一个标准的submit按钮。示例如下:
echo form_submit('mysubmit', 'Submit Post!');
会生成:
type="submit" name="mysubmit" value="Submit Post!" />
与其它函数类似,第一个参数你可以传递一个关联数组来设置你所需要的属性。第三个参数允许你添加一些额外的内容
到生成的HTML代码里。
帮助你生成一个label.示例如下:
echo form_label('你的名字是?','username');
会生成:
<label for="username">你的名字是?label>
与其它函数类似,你可以在第三个参数传入一个关联数组来增加一些额外的属性值。
$attributes = array(
'class' => 'mycustomclass',
'style' => 'color: #000;',
);
echo form_label('你的名字是?', 'username', $attributes);
会生成:
<label for="username" class="mycustomclass" style="color: #000;">你的名字是?label>
作用是生成一个标准的 reset 按钮。此函数用法与 form_submit() 完全相同。
作用是生成一个标准的按钮。你至少要给出两个参数,它们分别是按钮的名称和内容:
echo form_button('name','content');
将会生成
<button name="name" type="button">Contentbutton>
或者你也可以将一个包含有任何你想要的数据的关联数组作为参数传递过去:
$data = array(
'name' => 'button',
'id' => 'button',
'value' => 'true',
'type' => 'reset',
'content' => 'Reset'
);
echo form_button($data);
将会生成:
如果你希望表单包含一些额外的数据,例如JavaScript,你可以将一个字符串作为第三个参数传递过去:
$js = 'onClick="some_function()"';
echo form_button('mybutton', 'Click Me', $js);
作用是生成一个关闭 标签。使用此函数的唯一好处是,你可以将这个标签之后要添加的数据也传递过去。例
如:
$string = "
将会生成:
form>
div>div>
form_prep()
允许你放心地在表单元素中使用HTML字符(例如引号),不必担心破坏表单。考虑一下下面这个范例:
$string = 'Here is a string containing "quoted" text.';
type="text" name="myform" value=" />
因为上面的字符串中包含了引号,因而导致表单被破坏。form_prep()函数会转换HTML,因此可以放心使用:
type="text" name="myform" value=" />
说明: 如果你使用的是表单辅助函数中的任何一个,数据都会自动的进行预处理,所以没有必要调用本函数。只有当你
手动创建表单元素时,你才需要本函数。
允许你设置 input 或者 textarea 字段的值。你必须在第一个参数中指定字段名称。第二个参数是可选的,允许你给字
段设置一个默认值。例如:
type="text" name="quantity" value="" size="50" />
当上面的表单元素第一次加载时将会显示”0”。
如果你使用 下拉菜单,此函数允许你显示选中的菜单项。第一个参数必须包含下拉菜单的名称,第二个参数
必须包含每个菜单项的值。第三个参数是可选的,作用是设置菜单项为默认选中状态(使用TRUE/FALSE布尔值)。
范例:
<select name="myselect">
<option value="one" echo set_select('myselect', 'one', TRUE); ?> >Oneoption>
<option value="two" echo set_select('myselect', 'two'); ?> >Twooption>
<option value="three" echo set_select('myselect', 'three'); ?> >Threeoption>
select>
允许你显示一个处于提交状态的复选框。第一个参数必须包含此复选框的名称,第二个参数必须包含
它的值,第三个参数是可选的,作用是设置复选框为默认选中状态(使用TRUE/FALSE布尔值)。例如:
<input type="checkbox" name="mycheck" value="1" echo set_checkbox('mycheck', '1'); ?> />
<input type="checkbox" name="mycheck" value="2" echo set_checkbox('mycheck', '2'); ?> />
允许你显示那些处于提交状态的单选框。这个函数与前面的 set_checkbox() 是相同的。
<input type="radio" name="myradio" value="1" echo set_radio('myradio', '1', TRUE); ?> />
<input type="radio" name="myradio" value="2" echo set_radio('myradio', '2'); ?> />