Невозможно получить правильное значение в Ajax - PullRequest
0 голосов
/ 21 сентября 2018

Я делаю систему управления врачом.У меня есть три поля формы department, doctor и doctor_time.Используя AJAX, я могу получить имя доктора по департаментам, затем, когда я выберу имя доктора, я получу Дату этого доктора, но снова, если я поменяю имя доктора, я все равно получу дату старого доктора.В консоли массив дат врачей отображается правильно, но в HTML datepicker он не обновляется со сменой доктора.

VIEW

        <!-- DOCTIRS DEPARTMENT -->
        <div class="col-md-6">
          <div class="form-group">
            <label>DEPARTMENT</label>
            <select class="form-control" id="docdept" name="deptid">
              <option selected value="">SELECT FROM BELOW</option>
              <?php foreach($depts as $dept) : ?>
                <option value="<?php echo $dept['id'] ?>"><?php echo $dept['name'] ?></option>
              <?php endforeach; ?>
            </select>
          </div>
        </div>


      <!-- DEPARTMENT WISE DATA FETCHING OF DOCTOR -->
        <div class="col-6"> 

          <div class="form-group">
           <label>DOCTOR's Name</label>
            <select class="form-control" id="docname" name="doctorid" disabled>
              <option selected disabled>SELECT FROM BELOW</option>
            </select>
          </div>

        </div>
          <!-- DEPARTMENT WISE DOCTOR'S TIME FETCHING -->
           <div class="col-6"> 
            <div class="form-group">
              <label>DOCTOR Timings</label>

              <input type="text" id="doctortime" class="form-control doctortime" placeholder="Doctor Date" name="dates" data-date-format="mm/dd/yyyy" readonly />


          </div>
        </div>

JQuery

$(document).ready(function(){

 // Get The doctor Name department wise
  $('#docdept').on('change',function(){

    var docdept_id = $(this).val();

    // console.log(docdept_id);

      if(docdept_id == ''){
        $('#docname').prop('disabled',true);
        $('#doctortime').prop('readonly',true);
      }else{
        $('#docname').prop('disabled',false);

       // Ajax codeing start
       $.ajax({

           url:'http://localhost/doctor/admin/Bookings_controller/get_docname',
           type:"POST",
           data: {'docdept_id' : docdept_id},
           dataType:'json',
           success:function(data){
             $('#docname').html(data.docbox);
             // $('#doctortime').val(data.doctime);
           },
           error:function(){
             alert('error is there');
           }

       });
      }
  });

  //Get the Time of doctor doctor name wise
    $('#docname').on('change',function(){

      var docname_id = $(this).val();
      console.log(docname_id);

      if(docname_id == ''){
        $('#doctortime').prop('readonly',true);
      }else{
        $('#doctortime').prop('readonly',false);

       // Ajax codeing start
       $.ajax({

           url:"http://localhost/doctor/admin/Bookings_controller/get_doctime",
           type:"POST",
           data: {'docname_id' : docname_id},
           dataType:'json',
           success:function(data){

            // alert(data.doctime);
            // console.log(data.doctime);
            var onlyThisDates = data.doctime.split(",");

            console.log(onlyThisDates);

            $('#doctortime').datepicker({
                format: "mm/dd/yyyy",
                autoclose: true,
                beforeShowDay: function (date) {
                  var dt_ddmmyyyy = ('0' + (date.getMonth() + 1)).slice(-2)  + '/' + ('0' + date.getDate()).slice(-2) + '/' + date.getFullYear();                                     
                  return (onlyThisDates.indexOf(dt_ddmmyyyy) != -1);
                }
            });
           },
           error:function(){
             alert('error is there');
           }

       });   
    }
  });

});

Контроллер

public function doctor(){
        $data['subview'] = 'admin/doctor_view';
        $data['depts'] = $this->Doctors_model->get_dept();
        $this->load->view('admin_layout',$data);
    }

//Get Doctor name by selecting doctor department
public function get_docname(){
    $docdept_id = $this->input->post('docdept_id');
    $docs = $this->Doctors_model->get_docname_query($docdept_id);
    if(count($docs) > 0){

   // For The Doctor Name Get Department Wise
        $docbox = "";
        $docbox .='<option>Select Doctor from below</option>';
        foreach($docs as $doc){
            $docbox .='<option value="'.$doc['id'].'">'.$doc['name'].'</option>';
        }

        echo json_encode(array('docbox' => $docbox));
    }
}

// Get the times by doctor name wise
public function get_doctime(){

    $docname_id = $this->input->post('docname_id');
    $times = $this->Doctors_model->get_doctime_query($docname_id);
    if(count($times) > 0){

 // For The Doctor Name  Wise Time Get
     $doctime = "";
     $doctime .= $times['dates'];

        echo json_encode(array('doctime' => $doctime));
    }   

}

МОДЕЛЬ

    //get doctor By department 
    public function get_docname_query($docdept_id){
      $this->db->select('doctors.*,department.id as deptid,department.name as deptname');
      //joining The Department Table
      $this->db->join('department','department.id = doctors.specialisation','left');
      $query = $this->db->get_where('doctors',array('doctors.specialisation' => $docdept_id));
      return $query->result_array();
    }
   //GET DOCTOR TIME
  public function get_doctime_query($docname_id){


    $query= $this->db->get_where('doctors', array('id' => $docname_id));

    return $query->row_array();     
  } 

В базе данных у меня естьдва стола department и doctors.department таблица имеет id, name.doctors таблица имеет id, doc_name, timing.

Я использую Codeigniter.Я могу получить имя доктора, выбрав отдел и изменив отдел, имена врачей также меняются, но когда я пытаюсь получить дату, выбирая имя доктора, оно отображается правильно, но если я меняю имя доктора, то я 'Я не могу просмотреть измененную дату врачей.

Пожалуйста, дайте мне знать, что не так в моем коде.

1 Ответ

0 голосов
/ 21 сентября 2018

Попробуйте определить html часть в вашем контроллере, как вы определили во время запроса врача.

Контроллер

public function get_doctime(){

    $docname_id = $this->input->post('docname_id');
    $times = $this->Doctors_model->get_doctime_query($docname_id);
    if(count($times) > 0){

 // For The Doctor Name  Wise Time Get
     $doctime = "";
     // $doctime .= $times['dates'];
     $doctime .= '<label>DOCTOR TIMING</label> <input type="text" id="doctortime" class="form-control" name="dates" placeholder="Select Date" value-data="'.$times['dates'].'" data-date-format="mm/dd/yyyy"/>';

        echo json_encode(array('doctime' => $doctime));
    }   

}

Просмотр Добавьте класс dynamic после группы форм и добавьте value-data в поле ввода.

 <!-- DEPARTMENT WISE DOCTOR'S TIME FETCHING -->
           <div class="col-6"> 
            <div class="form-group dynamic">
              <label>DOCTOR Timings</label>

              <input type="text" id="doctortime" class="form-control doctortime" placeholder="Doctor Date" value-data="" name="dates" data-date-format="mm/dd/yyyy" readonly />


          </div>
        </div>

Jquery

  //Get the Time of doctor doctor name wise
    $('#docname').on('change ',function(){

      var docname_id = $(this).val();
      console.log(docname_id);

      if(docname_id == ''){
        $('#doctortime').prop('readonly',true);
      }else{
        $('#doctortime').prop('readonly',false);

       // Ajax codeing start
       $.ajax({

           url:"http://localhost/doctor/admin/Bookings_controller/get_doctime",
           type:"POST",
           data: {'docname_id' : docname_id},
           dataType:'json',
           success:function(data){
          //First Transfer the controller value to view
          $('.dynamic').html(data.doctime);

          // Get the value-data from the input field
            var dateval = $('.dynamic input').attr('value-data');
            var onlyThisDates = dateval.split(",");
            $('#doctortime').datepicker({
                format: "mm/dd/yyyy",
                autoclose: true,
                beforeShowDay: function (date) {
                  var dt_ddmmyyyy = ('0' + (date.getMonth() + 1)).slice(-2)  + '/' + ('0' + date.getDate()).slice(-2) + '/' + date.getFullYear();                                     
                  return (onlyThisDates.indexOf(dt_ddmmyyyy) != -1);
                }
            });
            // View Area 

           },
           error:function(){
             alert('error is there');
           }

       });   
    }
  });

Этот код будет работать дляконечно.Дайте мне знать.

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