恶魔家伙,
我最近一直在使用ajax,而且我在使用codeigniter表单验证库时遇到问题.我使用工具在函数http://formtorch.geekhut.org/中生成的示例.
现在,当我使用带有哑数据的json_encode()函数时,ajax完美地返回数据,但在示例中验证使用验证库而不是form_validation库,这似乎是较旧的版本.
为此,在该示例中,验证不适用于ajax,特别是$this-> form_validation-> run()函数使得ajax不返回结果,即使我在create_course()的开头使用json_encode()回显伪数据) .
所以用ajax进行验证有什么问题,并向我解释由控制器收到的ajax发送的数据.
所以这是我的代码:
- function create_course()
- {
- $this->form_validation->set_rules('course_code','course_code','trim|xss_clean|required');
- $this->form_validation->set_rules('name','name','xss_clean|required');
- // .. etc
- if ($this->form_validation->run()) {
- // validation ok
- $data['course_code'] = $this->form_validation->set_value('course_code');
- $data['name'] = $this->form_validation->set_value('name');
- // ... etc
- if ($this->models_facade->create_course($user_id,$data)) { // success
- $data = array( 'profile_change' => $this->lang->line('profile_change'));
- } else { // fail
- $data = array( 'profile_change_error' => $this->lang->line('profile_change_error'));
- }
- }
- else
- {
- $data = array(
- 'course_code' => $this->form_validation->course_code_error,'name' => $this->form_validation->name_error
- );
- }
- echo json_encode($data);
- }
这是Jquery Ajax功能
- $(function(){
- $("#submit").click(function(){
- var course_code = $("#course_code").val();
- var name = $("#name").val();
- // etc
- $.post("<?PHP echo base_url() ?>home/create_course",course_code:course_code,name:name},function(data){
- function(data){
- alert(data.data);
- $("#course_code_error").html(data.course_code);
- $("#name_error").html(data.name);
- },'json');
- });
- return false;
});
你使用什么版本的Codeigniter?你有没有记得在你的构造中加载验证库?
- $this->load->library('form_validation');