Я получаю данные на странице просмотра. Теперь я хочу выполнить поиск по некоторым данным, поступающим из текстового поля на той же странице просмотра.
Что я должен делать? Могу ли я использовать 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>
В заголовке вашего сообщения вы говорите, что хотите «отсортировать» данные, но в описании говорите, что хотите «найти» их.
Я бы порекомендовал делать это без 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&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, но если у вас есть много результатов, вам все равно нужно будет позвонить своему контроллеру и модели, как описано выше, чтобы выполнить тяжелую работу.
Других решений пока нет …