【发布时间】:2014-06-30 05:56:12
【问题描述】:
我正在尝试为用户提供一个搜索选项来填写和搜索多个表格中的订单、佣金等,而无需重新加载页面。以前从未使用过 AJAX,所以如果有人能指出我哪里出错或帮助我完成这项工作,将不胜感激!现在,当我单击提交按钮时,除了收到 500(内部服务器错误)消息外,什么也没有发生。
这是我的观点(家):
<div class="large-6 columns">
{{Form::open( array('route' => 'search', 'method' => 'post', 'id' => 'search_form'))}}
{{ Form::select('search_table',
array(
'select' => 'Search...',
'commissions' => 'Search commissions',
'estimates' => 'Search estimates',
'orders' => 'Search orders',
'warranties' => 'Search warranties',
), null, array('id' => 'search_table')) }}
<div class="search_box" id="search_column_div">
<!-- Search_column select goes here -->
</div>
<div id="search_input_div">
<!-- Search_input text field goes here -->
</div>
{{ Form::submit('Search', array('id' => 'search_button','class' => 'button expand radius search_button no_display'))}}
{{ Form::close() }}
</div>
<div id="search_results_div">
</div>
</div>
因为搜索有很多变量,但我不想让它占用很多空间,所以我让 JS 根据他们之前的选择插入查询的下一部分。因此,他们将从选择要搜索的表开始,然后是一列,然后他们将有一个输入字段来写他们正在搜索的确切内容。
JS(我的问题可能出在哪里):
$(document).ready(function($){
$('#search_form').on('submit', function(){
$.post(
$(this).prop('action'),{
"search_table": $('#search_table').val(),
"search_column": $('#search_column').val(),
"search_input": $('#search_input').val(),
},
function(data){
$('#search_results_div').html(data);
},
'json'
);
return false;
});
});
控制器:
public function searchPost(){
$search_table = Input::get('search_table');
$search_column = Input::get('search_column');
$search_input = Input::get('search_input');
$search = DB::table($search_table)->where($search_column, 'LIKE', "%{$search_input}%")->get();
return $search;
}
还有路线:
/*Search Page for Ajax*/
Route::post('/search', array(
'as' => 'search',
'uses' => 'HomeController@searchPost'
));
再次感谢您的宝贵时间和帮助!请随时就最佳做法提出建议!
【问题讨论】:
-
您发布的路由正在侦听 GET 请求,但您正在发布 AJAX 请求。
-
好点,更新了问题,但仍然收到 500 错误。
标签: javascript jquery mysql ajax laravel-4