Как отсортировать данные в просмотре страницы в codeigniter

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

Что я должен делать? Могу ли я использовать ajax или jQuery?

Это моя страница просмотра

<li class="">Doctors</li>
</ol>
<div class="list col-xs-8">
<div class="col-md-8 col-md-offset-2">
<?php echo $this->session->flashdata('msg'); ?>
</div>
<ul>
<input type="text" name="search_data" placeholder="Search ..." class="form-control"  id="search_data" onkeyup="ajaxSearch();"style=" height: 50px; width: 200px !important;">
<?php
if(isset($doc)):
foreach ($doc as $row):
?>
<li>
<div class="imgt"><img src="<?php echo base_url("./resources/images/");  if($row->dr_img) echo $row->dr_img;
else echo "no-img.jpg"; ?>" height="90px" width="82px">
</div>
<div class="text">
<h3><b>Dr. <?php echo  $row->dr_name;?></b><br></h3>
<p><?php echo $row->spec_specialise; ?><br><?php echo  $row->district;?><br><?php echo  $row->state;?></p>
</div>
<div class="text"></div>
<div class="link">
<a href="<?php echo site_url('User/doctor_profile_view/'.$row->id); ?>"><i class="ace-icon fa fa-eye sym"></i>View</a></div>
</li>
<?php endforeach;
endif;
?>
</ul>
<div class="space"></div>
</div>
</div>
<div class="pdt_rightt">
<center>
</center>
</div>

0

Решение

В заголовке вашего сообщения вы говорите, что хотите «отсортировать» данные, но в описании говорите, что хотите «найти» их.

Я бы порекомендовал делать это без Ajax, чтобы понять основы.

Ваше мнение может выглядеть так:

<?php echo form_open( current_url() ); ?>
<h2>Search</h2>
<input type="text" name="search" placeholder="Enter search word" />
<button>Search</button>
<?php echo form_close(); ?>

<?php if (isset($docs)) : ?>
<p>
<a href="<?php echo current_url(); ?>?sort=dr_name&amp;search=<?php echo html_escape( urlencode( $search ) ); ?>">
Sort by name
</a>
</p>
<ul>
<?php foreach ($docs as $row) : ?>
<li><?php echo html_escape( $row->dr_name ); ?></li>
<?php endforeach; ?>
</ul>
<?php endif; ?>

Тогда ваш контроллер будет выглядеть так:

public function index() {
$search = $this->input->get_post('search');
$sort = $this->input->get('sort');
$docs = $this->doc_model->get_docs( $search, $sort );

$data = array(
'search' => $search,
'sort'   => $sort,
'docs'   => $docs
);
$this->load->view('docs', $data);
}

Ваша модель затем должна будет выбрать всех докторов, если $ search равно нулю, или запросить имена докторов с помощью $ search, если она не равна нулю. Аналогично, если $ sort равен нулю, вы упорядочиваете поле по умолчанию (например, дата создания).

Если у вас много результатов, вам также следует взглянуть на класс разбивки на страницы в CI, чтобы охватить результаты на нескольких страницах.

Вы можете достичь всего этого, используя Ajax, но если у вас есть много результатов, вам все равно нужно будет позвонить своему контроллеру и модели, как описано выше, чтобы выполнить тяжелую работу.

0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]