- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我尝试创建一个查找器(一种高级搜索),但我已经完成了一半,但在获取搜索查询的第三部分时遇到了问题。
基本上用户会选择类别,然后选择该类别的子类别直到这里我已经完成
然后该子类别产品的所有规范和品牌都会呈现出来供选择。
My problem is to get specifications and brands from selected subcategory.
我想要根据所选子类别获取这些信息的原因是因为每个子类别产品都有不同的品牌和规范,例如我不想在用户选择鼠标时显示
子类别!任何类型的鼠标都没有 CPU,这就是全部原因。cpu
规范
Blade
<form action="" class="mt-20">
<div class="col-md-3">
<label for="category_id">category</label>
<select name="category_id" class="form-control">
<option value="">Select Category</option>
@foreach($findercategories as $category)
<option value="{{$category->id}}">{{$category->title}}</option>
@endforeach
</select>
</div><!-- end col-md-3 -->
<div class="col-md-3">
<label for="subcategory_id">subcategory</label>
<select name="subcategory_id" class="form-control">
<option value="">Select Subcategory</option>
</select>
</div><!-- end col-md-3 -->
<div class="col-md-3">
<label for="specification_id">specifications</label>
<select name="specification_id" class="form-control">
<option value="">Select Specification</option>
</select>
</div><!-- end col-md-3 -->
<div class="col-md-3">
<label for="brand_id">brands</label>
<select name="brand_id" class="form-control">
<option value="">Select Brand</option>
</select>
</div><!-- end col-md-3 -->
<div class="row">
<div class="col-md-3 col-md-offset-9">
<button style="margin: 20px;" class="pull-right btn btn-info" type="submit">Find</button>
</div>
</div>
</form>
Javascript
<script type="text/javascript">
$(document).ready(function() {
$('select[name="category_id"]').on('change', function() {
var categoryID = $(this).val();
if(categoryID) {
$.ajax({
url: '{{ url('getSubCategories') }}/'+encodeURI(categoryID),
type: "GET",
dataType: "json",
success:function(data) {
$('select[name="subcategory_id"]').empty();
$.each(data, function(key, value) {
$('select[name="subcategory_id"]').append('<option class="form-control" value="'+ value['id'] +'">'+ value['title'] +'</option>');
});
}
});
}else{
$('select[name="subcategory_id"]').empty();
}
});
});
</script>
<script type="text/javascript">
$(document).ready(function() {
$('select[name="subcategory_id"]').on('change', function() {
var subcategoryID = $(this).val();
if(subcategoryID) {
$.ajax({
url: '{{ url('getspecifications') }}/'+encodeURI(subcategoryID),
type: "GET",
dataType: "json",
success:function(data) {
$('select[name="specification_id"]').empty();
$.each(data, function(key, value) {
$('select[name="specification_id"]').append('<option class="form-control" value="'+ value['id'] +'">'+ value['title'] +'</option>');
});
}
});
}else{
$('select[name="specification_id"]').empty();
}
});
});
</script>
Controller
//get categories list
$findercategories = Category::ofStatus('Active')->get();
//finder (subcategories)
public function getSubCategories($id){
$subcategory = Subcategory::where('category_id', $id)->get();
return response()->json($subcategory);
}
//finder (specifications + brands)
public function getspecifications($id){
$product = Product::where('subcategory_id', $id)->get();
$productsubsp = DB::table('product_subspecification')->where('product_id', $product)->get();
$specifications = $productsubsp;
return response()->json($specifications);
}
路线
Route::get('/getSubCategories/{id}', 'frontend\SearchController@getSubCategories');
Route::get('/getspecifications/{id}', 'frontend\SearchController@getspecifications');
products
表的列中名为brand_id
product_subspecation
将获取 id
product_id
和subspecification_id
这就是我在前端获取这些信息的方式:
针对品牌
{{$product->brand->title}}
以及规范
在 Controller 中
$specifications = $product->subspecifications->mapToGroups(function ($item, $key) {
return [$item->specification->title => $item];
});
在 Blade 中
@foreach($specifications as $specificationtitle => $specificationcollection)
<tr>
<th style="width:150px;">{{ $specificationtitle }}</th>
<td class="text-left">
@foreach($specificationcollection as $subspecification)
{{$subspecification->title}}
@endforeach
</td>
</tr>
@endforeach
返回结果如下:
CPU CORE I5 CORE I3 CORE I7
RAM 2 GIG 4 GIG
我设法在规范下拉列表中获得结果,但是我无法在所选子类别下获取所有产品我只能获取最后一个产品
,而不是全部。
这是我当前获取结果的方式
public function getspecifications($id){
//find products under subcategory
$product = DB::table('products')
->where('subcategory_id', $id)
->get();
foreach($product as $pp) {
}
$specificationsw = $pp->id; //get products id (currently has issue, only gets 1)
// find products specification with same product id
$specificationss = DB::table('product_subspecification')
->where('product_id', $specificationsw)->get();
foreach($specificationss as $dd) {
}
$specificationsss = $dd->subspecification_id; //get specifications id from product_subspecification table
// get specifications title base on table above
$specifications = DB::table('subspecifications')
->where('id', $specificationsss)->get();
return response()->json($specifications);
}
知道如何获取我的所有产品id
,而不是仅获取我当前获取的最后一个产品
吗?
我将 Controller 更改为下面的代码,现在我可以从子类别中获取所有产品:
public function getspecifications($id){
//find products under subcategory
$product = DB::table('products')
->where('subcategory_id', $id)
->get();
$date = array();
foreach ($product as $stan) {
$date[] = $stan->id;
}
$specificationsw = $date; //get products id (currently has issue, only gets 1)
// find products specification with same product id
$specificationss = DB::table('product_subspecification')
->where('product_id', $specificationsw)->get();
$date2 = array();
foreach ($specificationss as $stan2) {
$date2[] = $stan2->subspecification_id;
}
$specificationsss = $date2; //get specifications id from product_subspecification table
// get specifications title base on table above
$specifications = DB::table('subspecifications')
->where('id', $specificationsss)->get();
$date3 = array();
foreach ($specifications as $stan3) {
$date3[] = $stan3;
}
$specifications = $date3;
return response()->json($specifications);
}
现在这是我的 dd
结果:
dd($specationssw);
products dd 这是产品的 id 2 个产品
array:2 [▼
0 => 27
1 => 38
]
dd($specationsss);
product_subspecification 表结果仅返回产品 id 27 的值。产品 id 38 不返回值!
array:2 [▼
0 => 5
1 => 8
]
dd($specations);
我的函数最后一部分的结果我在前端的ajax代码中得到了这个标题
但是正如你看到的关于的信息>subspesification
id 8
和 product
id 38
丢失。
array:1 [▼
0 => {#722 ▼
+"id": 5
+"title": "4 GIG"
+"specification_id": 2
+"created_at": "2017-12-04 00:00:00"
+"updated_at": "2017-12-04 00:00:00"
}
]
最佳答案
我在这里解决了我的问题,供有需要的人使用:
说明:
规范
,注释
在我的案例中,规范存储在其表中并与我的产品相关 sync method在第三个表中。 (仅显示该子类别下的产品中使用的规范)品牌
(仅显示该子类别下的产品中使用的品牌) Controller
方法
//finder (find subcategories base on selected category)
public function getSubCategories($id){
$subcategory = Subcategory::where('category_id', $id)->get();
return response()->json($subcategory);
}
//finder (show specifications base on selected subcategory)
public function getspecifications($id){
$specifications = DB::table('products')
->where('subcategory_id', $id)
->join('product_subspecification', 'product_subspecification.product_id', '=', 'products.id')
->join('subspecifications', 'subspecifications.id', '=', 'product_subspecification.subspecification_id')
->groupBy('subspecifications.id')
->get();
return response()->json($specifications);
}
//finder (show brands base on selected subcategory)
public function getbrands($id){
$specifications = DB::table('products')
->where('subcategory_id', $id)
->join('brands', 'brands.id', '=', 'products.brand_id')
->groupBy('brand_id')
->get();
return response()->json($specifications);
}
Important: In order to avoid duplicated results in
specifications
andbrands
I usedgroupBy
.
路线
Route::get('/getSubCategories/{id}', 'frontend\SearchController@getSubCategories');
Route::get('/getspecifications/{id}', 'frontend\SearchController@getspecifications');
Route::get('/getbrands/{id}', 'frontend\SearchController@getbrands');
脚本
<script type="text/javascript">
$(document).ready(function() {
$('select[name="category_id"]').on('change', function() {
var categoryID = $(this).val();
if(categoryID) {
$.ajax({
url: '{{ url('getSubCategories') }}/'+encodeURI(categoryID),
type: "GET",
dataType: "json",
success:function(data) {
$('select[name="subcategory_id"]').empty();
$.each(data, function(key, value) {
$('select[name="subcategory_id"]').append('<option class="form-control" value="'+ value['id'] +'">'+ value['title'] +'</option>');
});
}
});
}else{
$('select[name="subcategory_id"]').empty();
}
});
});
</script>
<script type="text/javascript">
$(document).ready(function() {
$('select[name="subcategory_id"]').on('change', function() {
var subcategoryID = $(this).val();
if(subcategoryID) {
$.ajax({
url: '{{ url('getspecifications') }}/'+encodeURI(subcategoryID),
type: "GET",
dataType: "json",
success:function(data) {
$('select[name="specification_id"]').empty();
$.each(data, function(key, value) {
$('select[name="specification_id"]').append(
"<option class='form-control' value='"+ value['id'] +"'>"+ value['title'] +"</option>"
);
});
}
});
}else{
$('select[name="specification_id"]').empty();
}
});
});
</script>
<script type="text/javascript">
$(document).ready(function() {
$('select[name="subcategory_id"]').on('change', function() {
var subcategoryID = $(this).val();
if(subcategoryID) {
$.ajax({
url: '{{ url('getbrands') }}/'+encodeURI(subcategoryID),
type: "GET",
dataType: "json",
success:function(data) {
$('select[name="brand_id"]').empty();
$.each(data, function(key, value) {
$('select[name="brand_id"]').append('<option class="form-control" value="'+ value['id'] +'">'+ value['title'] +'</option>');
});
}
});
}else{
$('select[name="brand_id"]').empty();
}
});
});
</script>
关于javascript - 在 Laravel 中获取基于 Ajax 的数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48638054/
我需要将文本放在 中在一个 Div 中,在另一个 Div 中,在另一个 Div 中。所以这是它的样子: #document Change PIN
奇怪的事情发生了。 我有一个基本的 html 代码。 html,头部, body 。(因为我收到了一些反对票,这里是完整的代码) 这是我的CSS: html { backgroun
我正在尝试将 Assets 中的一组图像加载到 UICollectionview 中存在的 ImageView 中,但每当我运行应用程序时它都会显示错误。而且也没有显示图像。 我在ViewDidLoa
我需要根据带参数的 perl 脚本的输出更改一些环境变量。在 tcsh 中,我可以使用别名命令来评估 perl 脚本的输出。 tcsh: alias setsdk 'eval `/localhome/
我使用 Windows 身份验证创建了一个新的 Blazor(服务器端)应用程序,并使用 IIS Express 运行它。它将显示一条消息“Hello Domain\User!”来自右上方的以下 Ra
这是我的方法 void login(Event event);我想知道 Kotlin 中应该如何 最佳答案 在 Kotlin 中通配符运算符是 * 。它指示编译器它是未知的,但一旦知道,就不会有其他类
看下面的代码 for story in book if story.title.length < 140 - var story
我正在尝试用 C 语言学习字符串处理。我写了一个程序,它存储了一些音乐轨道,并帮助用户检查他/她想到的歌曲是否存在于存储的轨道中。这是通过要求用户输入一串字符来完成的。然后程序使用 strstr()
我正在学习 sscanf 并遇到如下格式字符串: sscanf("%[^:]:%[^*=]%*[*=]%n",a,b,&c); 我理解 %[^:] 部分意味着扫描直到遇到 ':' 并将其分配给 a。:
def char_check(x,y): if (str(x) in y or x.find(y) > -1) or (str(y) in x or y.find(x) > -1):
我有一种情况,我想将文本文件中的现有行包含到一个新 block 中。 line 1 line 2 line in block line 3 line 4 应该变成 line 1 line 2 line
我有一个新项目,我正在尝试设置 Django 调试工具栏。首先,我尝试了快速设置,它只涉及将 'debug_toolbar' 添加到我的已安装应用程序列表中。有了这个,当我转到我的根 URL 时,调试
在 Matlab 中,如果我有一个函数 f,例如签名是 f(a,b,c),我可以创建一个只有一个变量 b 的函数,它将使用固定的 a=a1 和 c=c1 调用 f: g = @(b) f(a1, b,
我不明白为什么 ForEach 中的元素之间有多余的垂直间距在 VStack 里面在 ScrollView 里面使用 GeometryReader 时渲染自定义水平分隔线。 Scrol
我想知道,是否有关于何时使用 session 和 cookie 的指南或最佳实践? 什么应该和什么不应该存储在其中?谢谢! 最佳答案 这些文档很好地了解了 session cookie 的安全问题以及
我在 scipy/numpy 中有一个 Nx3 矩阵,我想用它制作一个 3 维条形图,其中 X 轴和 Y 轴由矩阵的第一列和第二列的值、高度确定每个条形的 是矩阵中的第三列,条形的数量由 N 确定。
假设我用两种不同的方式初始化信号量 sem_init(&randomsem,0,1) sem_init(&randomsem,0,0) 现在, sem_wait(&randomsem) 在这两种情况下
我怀疑该值如何存储在“WORD”中,因为 PStr 包含实际输出。? 既然Pstr中存储的是小写到大写的字母,那么在printf中如何将其给出为“WORD”。有人可以吗?解释一下? #include
我有一个 3x3 数组: var my_array = [[0,1,2], [3,4,5], [6,7,8]]; 并想获得它的第一个 2
我意识到您可以使用如下方式轻松检查焦点: var hasFocus = true; $(window).blur(function(){ hasFocus = false; }); $(win
我是一名优秀的程序员,十分优秀!