我有一个公司比较网络应用程序,允许用户在不同的选择下拉列表中选择2个公司并将它们并排比较 . 到目前为止,一切都运作良好,除了订购 . 我希望比较的结果基于首先查询的项目,而不是默认的Laravel created_by字段 . 下面是我的查询生成器代码:
public function compareCompanies(Request $request) {
if ($request->has('companies') && $request->companies != null ) {
$companies = array_filter($request->companies);
$brands = Brand::with('categories')
->whereIn('brands.slug', $companies)
->get();
return response()->json(['success' => true, 'brands' => $brands]);
}
}
以下是我的ajax,用于显示POST请求的响应
$.ajax({
type: "POST",
url : url,
data: $("#compareForm").serialize(),
dataType : 'json',
success : function(response) {
if(response.success)
{
$("div#divLoading").removeClass('show');
$.each(response.brands, function(i, brand){
var NewRow = '';
NewRow += '<table class="table"><thead><tr>';
NewRow += '<th>' + brand.brand + '</th>';
NewRow += '</tr></thead><tbody>';
NewRow += '<tr><td>'+brand.growth_score+'</td></tr>';
NewRow += '<tr><td>'+brand.mind_share +'</td></tr>';
NewRow += '<tr><td>'+brand.headquarters+'</td></tr>';
NewRow += '<tr><td>'+brand.revenue+'</td></tr>';
NewRow += '<tr><td>'+brand.no_of_employees+'</td></tr>';
NewRow += '</tbody></table></div>';
$("#companies").append(NewRow);
})
}
},
error: function (data) {
console.log('An error occurred.');
console.log(data);
}
});
我得到的结果如下图所示:
如您所见,结果是交换的,因为Laravel使用created_at的值进行排序 . 如何根据输入顺序订购结果?
1 回答
Eloquent允许您通过在使用orderBy方法时指定列来订购查询结果,如下所示:
因此,如果您使用请求提交列名,则可以动态更改数据应按哪个列排序: