使用codeigniter处理表单时ajax的问题

时间:2011-02-10 21:12:43

标签: php jquery ajax codeigniter webforms

我在尝试通过ajax提交表单时遇到问题。如果我只输入名字并提交它,它会给我一个姓氏错误。如果我只输入姓氏,它会给我第一个名字的错误。这就是我的期望。

现在如果我同时输入名字和姓氏并提交表单,则在firebug中它会在控制台中给出错误“msg is null”。如果提交了名字和姓氏,msg如何为null,而不是在单独提交名字或姓氏时呢?

我的表单包含以下内容:

<p class="inline-medium-label"><span class="relative">
   <?php echo form_error('firstName'); ?>
   <label for="firstName" class="required">First Name</label>
   <input type="text" class="full-width" name="firstName" value="<?php echo set_value('firstName'); ?>" /><br />
</span></p>

<p class="inline-medium-label"><span class="relative"> 
   <?php echo form_error('lastName'); ?>
   <label for="lastName" class="required">Last Name</label>
   <input type="text" class="full-width" name="lastName" value="<?php echo set_value('lastName'); ?>" /><br />
</span></p>

我的ajax电话

$.ajax({
   url: 'addMember',
   type: 'post',
   data: data,
   dataType: 'json',
   success: function(msg) {
      if(msg.validate === false) {  // if there are validation errors...
         if(msg.firstName != '') {
        $('input[name="firstName"]').addClass('error');
        $('input[name="firstName"]').after('<span class="check-error"></span>');
     }
     if(msg.lastName != '') {
        $('input[name="lastName"]').addClass('error');
        $('input[name="lastName"]').after('<span class="check-error"></span>');
     }
      } else {
         $('div.modal-content').append('<h2>User Added Successfully!</h2>');
      }
   }
});

我的处理ajax的控制器

function addMember ()
{   
   $data['sess'] = $this->session;  

   // validates and sanitizes the user's input
   $this->form_validation->set_rules('firstName', 'First Name', 'trim|required|max_length[30]|xss_clean');
   $this->form_validation->set_rules('lastName', 'Last Name', 'trim|required|max_length[30]|xss_clean');

   // if there are validation errors...
   if($this->form_validation->run() == FALSE)
   {    
      if($this->input->post('ajax'))    // if the form was submitted with ajax...
      {
         echo json_encode(array('validate'=>FALSE, 
                            'firstName'=>form_error('firstName'), 
                'lastName'=>form_error('lastName')
                  ));
      }
      else  // else if NOT submitted with ajax...
      {
         echo 'Ajax not used';
      }
   }
   else // if there are NO validation errors
   {

   }    
}

1 个答案:

答案 0 :(得分:4)

嗯,这只是因为在你的else子句中(当数据验证时)你什么都不做。

所以是的,返回到你的javascript函数的数据将为null

   else // if there are NO validation errors
   {
        //You should output something here
   }  

希望有所帮助