отображать количество по группам в зависимости от текстового поля в ajax и codeigniter - PullRequest
0 голосов
/ 04 декабря 2018

Мне трудно получить общее количество зачисленных учащихся в секцию класса.

Я пытаюсь выбрать количество учащихся в каждом разделе, используя ajax, чтобы определить, достигнуто ли число учащихся или мы можем выполнить корректировку.в рассадке, как на изображении выше.

регистрационная форма

Это мой javascript

<script type="text/javascript">
  $(document).ready(function () {
    var section_id_post = '<?php echo $student['section_id']; ?>';
    var class_id_post = '<?php echo $student['class_id']; ?>';
    populateSection(section_id_post, class_id_post);
    function populateSection(section_id_post, class_id_post) {
        $('#section_id').html("");
        var base_url = '<?php echo base_url() ?>';
        var div_data = '<option value=""><?php echo $this->lang->line('select'); ?></option>';
        $.ajax({
            type: "GET",
            url: base_url + "sections/getByClass",
            data: {'class_id': class_id_post},
            dataType: "json",
            success: function (data) {
                $.each(data, function (i, obj)
                {
                    var select = "";
                    if (section_id_post == obj.section_id) {
                        var select = "selected=selected";
                    }
                    div_data += "<option value=" + obj.section_id + " " + select + ">" + obj.section + "</option>";
                });

                $('#section_id').append(div_data);
            }
        });
    }

    $(document).on('change', '#class_id', function (e) {
        $('#section_id').html("");
        var class_id = $(this).val();
        var base_url = '<?php echo base_url() ?>';
        var div_data = '<option value=""><?php echo $this->lang->line('select'); ?></option>';
        $.ajax({
            type: "GET",
            url: base_url + "sections/getByClass",
            data: {'class_id': class_id},
            dataType: "json",
            success: function (data) {
                $.each(data, function (i, obj)
                {   
                    div_data += "<option value=" + obj.section_id + ">" + obj.section + "</option>";
                });
                $('#section_id').append(div_data);
            }
        });
    });



    var date_format = '<?php echo $result = strtr($this->customlib->getSchoolDateFormat(), ['d' => 'dd', 'm' => 'mm', 'Y' => 'yyyy',]) ?>';
    $('#dob,#admission_date').datepicker({
        format: date_format,
        autoclose: true
    });
});

Этоmy View

<div class="col-md-3">
  <div class="form-group">
    <label>Select Section</label>
      <select  id="section_id" name="section_id" class="form-control" >
         <option value="">Select</option>
      </select>
  </div>
</div>
<div class="col-md-2">
  <div class="form-group"><label>Number of Students</label>
       <input id="noStd" name="noStd" class="form-control" readonly="readonly"/>
  </div>
</div>

My Control

function numberOfStd() {
   $section_id = $this->section_model->get('section_id');
    foreach ($section_id as $key => $value) {
        if ($value["id"] != 0) {
            $count_student[$value["section"]] = $this->studentsession_model->countStudentBySessionBySection($value["id"]);
        }
    }
    $data["count_student_section"] = $count_student;
}

Моя модель

 public function countStudentBySessionBySection($id){
    $query = $this->db->select("*")->join("students", "students.id = student_session.student_id")->where("student_session.section_id", $id)->get("student_session");
    return $query->num_rows();
} 
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...