恶魔家伙,
我最近一直在使用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');