2012-04-20 55 views
6

嗨,大家好,我只想问为什么我的ajax请求得到一串FALSE(它应该从控制器得到错误消息)。通过jquery ajax和codeigniter得到验证错误

这里是控制器

function ajax_verify(){ 
    $this->form_validation->set_rules('username', '', 'max_length[25]|min_length[4]|trim|required|xss_clean'); 
    $this->form_validation->set_rules('email', '', 'valid_email|required|trim|xss_clean'); 

    if($this->form_validation->run()==FALSE){ 
      $errors = $this->form_validation->error_array(); 
      echo json_encode($this->form_validation->error_array()); 
    }else{ 
      echo "Success!"; 
     } 

    } 

我扩展库以获取错误消息的片段(它的工作原理完全正常的PHP验证)

class MY_Form_validation extends CI_Form_validation{ 


function __construct(){ 
    parent::__construct(); 
} 

function error_array(){ 
    if(count($this->_error_array)===0){ 
     return FALSE; 
    }else{ 
     return $this->_error_array; 
    } 
} 

function get_tae(){ 
    return "TAE!"; 
} 
} 

和持续的视图和jQuery的AJAX代码(返回错误而不是错误)。

 <!DOCTYPE HTML> 
    <html> 
    <head> 
      <meta charset="utf-8"> 
      <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7/jquery.js"></script> 
     <title>Title</title> 
    <body> 

    <?php //echo validation_errors('<div class="error">', '</div>');?> 
    <?php echo form_open('ajax/ajax_verify', array('id'=>'my_form'));?> 
    <?php echo form_label('Username'); ?> 
    <?php echo form_input('username', '', array('id' => 'username'));?> 
    <?php echo form_label('Email Address'); ?> 
    <?php echo form_input('email', '', array('id' => 'email')); ?> 
    <?php echo form_submit('submit', 'Submit'); ?> 
    <?php echo form_close();?> 

    <script type="text/javascript"> 
    $(function(){ 
      $('#my_form').submit(function(e){ 
       $.get('ajax_verify', function(data){ 
        $('#contents').append(data); 
       }, 'json') ;     
       e.preventDefault(); 
      }) 


     }); 
      </script> 
+1

这是正确的吗? '($ this - > _ error_array)' – 2012-04-20 09:33:00

+0

我认为这是它在php验证中的工作,也许问题是在jQuery代码中获取错误字符串而不是像这样的错误消息 {“username”:“用户名字段是需要。“,”email“:”电子邮件字段是必需的。“} – tastebuds 2012-04-20 09:47:30

回答

3

它:

echo json_encode(validation_errors()); 

OR - 独立

$arr = array(
    'field_name_one' => form_error('field_name_one'), 
    'field_name_two' => form_error('field_name_two') 
); 

echo json_encode($arr); 
+0

我试过了,但是..同样的结果,我不知道也许问题是我的ajax代码总是得到错误的输出。 。 – tastebuds 2012-04-22 23:40:39

6

试试这个。它会正常工作。

在控制器添加这两种方法

public function CreateStudents() { 

     $this->load->helper('form'); 

     $data['title'] = "Create Students Page"; 
     $data['success'] = ""; 
     $this->load->view('templates/header', $data); 
     $this->load->view('createstudents', $data); 
     $this->load->view('templates/footer', $data); 

    } 

    public function CreateStudentsAjax() { 

     $this->load->helper('form'); 
     $this->load->library('form_validation'); 
     $this->form_validation->set_error_delimiters('', ''); 

     $this->form_validation->set_rules('roll', 'Roll Number', 'required'); 
     $this->form_validation->set_rules('name', 'Name', 'required'); 
     $this->form_validation->set_rules('phone', 'Phone', 'required'); 

     if ($this->form_validation->run()) { 

      $this->welcome_model->InsertStudents(); 
      echo json_encode("Oks"); 
     } else { 

      $data = array(
       'roll' => form_error('roll'), 
       'name' => form_error('name'), 
       'phone' => form_error('phone') 
      ); 

      echo json_encode($data); 
     } 
    } 

在视图中添加形式DIV命名为 “mesage

<div id="message"> 


     </div> 

     <?php echo form_open('welcome/CreateStudentsAjax'); ?> 

     <label for="roll">Student Roll Number</label> 
     <input type="text" id="txtRoll" value="" name="roll"/> 

     <label for="Name">Students Name</label> 
     <input type="text" id="txtName" value="" name="name"/> 

     <label for="Phone">Phone Number</label> 
     <input type="text" id="txtPhone" value="" name="phone"/> 

     <input type="submit" name="submit" value="Insert New Students" /> 

     <?php echo '</form>'; ?> 

现在脚本包含

<script type="text/javascript"> 

      $(document).ready(function(){ 

       $('form').submit(function(){ 
        //alert('ok');  
        $.ajax({ 
         url:this.action, 
         type:this.method, 
         data:$(this).serialize(), 
         success:function(data){ 
          var obj = $.parseJSON(data); 

          if(obj['roll']!=null) 
          {        
           $('#message').text(""); 
           $('#message').html(obj['roll']); 
           $('#message').append(obj['name']); 
           $('#message').append(obj['phone']); 
          } 
          else 
          {        
           $('#message').text(""); 
           $('#message').html(obj); 
          } 

         }, 
         erro:function(){ 
          alert("Please Try Again"); 
         }       
        }); 
        return false; 
       });       
      }); 

     </script> 
+0

这很有帮助。应该标记为正确答案。 – 2017-05-01 08:04:00