Проверка формы в Codeigniter на ajax Отправке формы - PullRequest
0 голосов
/ 21 апреля 2020

Я новичок в codeigniter & javascript, я работал с отправкой формы через ajax в codeigniter. Мне нужно использовать проверку формы в текстовом поле и другие входные данные в форме. Я искал в Интернете и не мог найти какие-либо ресурсы или ссылки. В настоящее время отправка формы работает нормально, мне просто нужно подтвердить свои данные, используя Jquery или ajax.

Вот моя модель

class test_model extends CI_Model {
    function save_data()
        {
            $name = $this->input->post('Name');
            $email = $this->input->post('Email');
            $contact = $this->input->post('Contact');
            $sex = $this->input->post('Sex');
            $country = $this->input->post('Country');   
            $data = array(
                'Name' => $name,
                'Email' => $email,
                'Contact' => $contact,
                'Sex' => $sex,
                'Country' => $country);
            $result = $this->db->insert('test2',$data);
            return $result;
        }
     }

Мой контроллер просто перенаправляет данные в модель

class test extends CI_Controller {
    function __construct() {
        parent::__construct();
        $this->load->model('test_model');
        $this->load->helper('url');
    }
    function index() {
        $this->load->view('test_index');
    }       
    function save() { 
        $data = $this->test_model->save_data();
        echo json_encode($data);        
    }
}

Вот мой взгляд

<form>
    <div class="container" style="padding-top: 80px;">

        <div class="form-group">
            <label for="Name">First Name :</label>
            <div class="col-md-4">
                <input type="text" name="Name" id="Name" class="form-control" placeholder="Your Name..">
            </div>
        </div>

        <div class="form-group">
            <label for="Contact">Contact :</label>
            <div class="col-md-4">
                <input type="text" class="form-control" id="Contact" name="Contact" placeholder="Your Contact No..">
            </div>
        </div>

        <div class="form-group">
            <label for="Sex" class="col-md-1">Gender :</label>
            <div class="form-check form-check-inline">
                <label >
                <input type="radio" class="form-check-input" name="Sex" id="Sex" value="Male">Male  </label><span style="padding-right: 10px;"></span>

                <label>
                <input type="radio" class="form-check-input" name="Sex" id="Sex" value="Female">Female </label>
            </div>
        </div>

            <div class="form-group">
                <select class="form-control custom-select col-md-4" id="Country" name="Country">
                    <option value="">Select Country</option>
                    <option value="Europe">Europe</option>
                    <option value="United Stated of America">United States of America</option>
                    <option value="India">India</option>
                </select>
            </div>

        <div class="form-group">
            <button type="button" type="submit" id="btn_save" class="btn btn-primary" >
                <span class="spinner-border spinner-border-sm"></span>Create</button>
            <button type="button"  class="btn btn-secondary" >Close</button>
        </div>
    </div>
</form>

Мой JS код ниже:

$('#btn_save').on('click',function() {
                    var Name = $('#Name').val();
                    var Email = $('#Email').val();
                    var Contact = $('#Contact').val();
                    var Sex = $('input[name="Sex"]:checked').val();
                    var Country = $('#Country').find(":selected").val();
                    $.ajax({
                        type : "POST",
                        url : "https://localhost/newCrud/test/save",
                        dataType : "JSON",
                        data: {"Name":Name, "Email":Email, "Contact":Contact, "Sex":Sex, "Country":Country},
                        success : function (data) {
                            if(data == 1) {
                                $('[name = "Name"]').val("");
                                $('[name = "Email"]').val("");
                                $('[name = "Contact"]').val("");
                                $('[name = "Sex"]').val("");
                                $('[name = "Country"]').val();

                                alert("Data Inserted"); }
                        }
                    });
                    return false;
                });
        });

Ребята, мой вышеприведенный код работает отлично, мне нужна ваша помощь, чтобы узнать, как я могу проверить свою форму, используя ajax, так как она уже передает данные в модель из Вот. Насколько я знаю, метод Codeigniter form_validate нельзя использовать при отправке ajax формы. Очень нужна ваша помощь, ребята. Спасибо за ваше время и предложения.

Ответы [ 2 ]

0 голосов
/ 22 апреля 2020

Просто используйте плагин jQuery Validate (https://jqueryvalidation.org/).

jQuery:

$(document).ready(function () {

$('#myform').validate({ // initialize the plugin
    rules: {
        field1: {
            required: true,
            email: true
        },
        field2: {
            required: true,
            minlength: 5
        }
    }
});

});

HTML:

<form id="myform">
<input type="text" name="field1" />
<input type="text" name="field2" />
<input type="submit" />
</form>
0 голосов
/ 21 апреля 2020

Почему бы не ????

Вы можете использовать Проверка CI , так как это встроенный метод проверки на стороне сервера, и вы вы попадаете на ваш сервер через AJAX

Вам нужно немного изменить свой код

$.ajax({
    type : "POST",
    url : "https://localhost/newCrud/test/save",
    dataType : "JSON",
    data: {"Name":Name, "Email":Email, "Contact":Contact, "Sex":Sex, "Country":Country},
    success : function (data) {
        if(data == 1) {
            $('.form-group').removeClass('has-error');
            $('[name = "Name"]').val("");
            $('[name = "Email"]').val("");
            $('[name = "Contact"]').val("");
            $('[name = "Sex"]').val("");
            $('[name = "Country"]').val();

            alert("Data Inserted"); 
        }
    },
    error : function (error) {
      if(error.status == 500){
        var response = error.responseJSON.validation;
        $('.form-group').removeClass('has-error');
        $.each(response, function(index, item) {
            $('[name='+index+']').closest('.form-group').addClass('has-error');
        });
      }
    }

});

Обновите свой контроллер следующим образом

public function save() { 
  // add this if not loaded earlier
  $this->load->library('form_validation');

  $this->form_validation->set_rules('Name','Name', 'required');
  $this->form_validation->set_rules('Contact','Contact', 'required');
  $this->form_validation->set_rules('Email','Email Address','required|valid_email');
  if ($this->form_validation->run() == FALSE) {
      $validation = $this->form_validation->error_array();
      return $this->output
              ->set_content_type('application/json')
              ->set_status_header(500)
              ->set_output( json_encode(array(
                  'validation' => $validation,
                  'message' => 'validation error !!!'
              )) );
  } 

  $data = $this->test_model->save_data();
  echo json_encode($data);        
}

Здесь я проверил 3 имени поля, адрес электронной почты и контакт. Также я использовал bootstrap класс ошибок 'has-error', чтобы выделить неисправные элементы.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...