php - 如何允许 URL 使用多个参数更改查询?
问题描述
我想根据通过 URL: 传递的查询参数显示数据https://example.com/?make=nike&model=shox&colour=white&body_type=slim
。
我可以通过访问来浏览“耐克”股票
https://example.com/?make=nike
。我可以通过访问来浏览“nike shox”
https://example.com/?make=nike&model=shox
。我无法浏览“nike shox white”
https://example.com/?make=nike&model=shox&colour=white
,因为我得到了与查询无关的混合结果。我无法浏览“nike shox white slim”
https://example.com/?make=nike&model=shox&colour=white&body_type=slim
,因为我得到了与查询无关的混合结果。我可以访问 "white"
https://example.com/?colour=white
。我可以访问 "slim"
https://example.com/?body_type=slim
。
我正在使用以下代码:
if ( isset( $query->query_vars['post_type'] ) && $query->query_vars['post_type'] == 'post' ) {
// allow the url to alter the query
if ( isset( $_GET['make'] ) ) {
$query->set( 'meta_key', 'make' );
$query->set( 'meta_value', $_GET['make'] );
}
if ( isset( $_GET['model'] ) ) {
$query->set( 'meta_key', 'model' );
$query->set( 'meta_value', $_GET['model'] );
}
if ( isset( $_GET['colour'] ) ) {
$query->set( 'meta_key', 'colour' );
$query->set( 'meta_value', $_GET['colour'] );
}
if ( isset( $_GET['body_type'] ) ) {
$query->set( 'meta_key', 'body_type' );
$query->set( 'meta_value', $_GET['body_type'] );
}
}
我究竟做错了什么?干杯!
解决方案
每次调用$query->set( 'key', 'value' );
之前的值都会被覆盖。
如果我猜对了,参数?make=nike&model=shox
只是“工作”,因为shox
是最后一个参数,并且只有shox
带有make=nike
.
你可以这样做:
$metaQuery = [];
if ( isset( $_GET['make'] ) ) {
$metaQuery[] = [
'key' => 'make',
'value' => $_GET['make'],
'compare' => '=',
];
}
if ( isset( $_GET['model'] ) ) {
$metaQuery[] = [
'key' => 'model',
'value' => $_GET['model'],
'compare' => '=',
];
}
if ( isset( $_GET['colour'] ) ) {
$metaQuery[] = [
'key' => 'colour',
'value' => $_GET['colour'],
'compare' => '=',
];
}
if ( isset( $_GET['body_type'] ) ) {
$metaQuery[] = [
'key' => 'body_type',
'value' => $_GET['body_type'],
'compare' => '=',
];
}
$query->set( 'meta_query', $metaQuery );
foreach()
您可以使用超全局上的循环来做得更干净$_GET
。
$metaQuery = [];
foreach ( $_GET as $metaKey => $metaValue ) {
$metaQuery[] = [
'key' => $metaKey,
'value' => $metaValue,
'compare' => '=',
];
}
if ( count( $metaQuery ) > 0 ) {
$query->set( 'meta_query', $metaQuery );
}
推荐阅读
- pyspark - PySpark 使用分组平均值填充缺失/错误值
- java - 无法在项目 SpringData 上执行目标 org.codehaus.mojo:exec-maven-plugin:1.2.1:exec (default-cli)
- database - Google App Maker - 如何绑定到查询数据源上的关系?
- python - 如何从 PISA 接口列表中制作 pandas DataFrame
- javascript - 是否可以使用数组元素作为类实例名称?
- c# - 使用 AutoMapper 将父类 Dto 映射到子类 ViewModel
- excel - Excel:Countif 包含引用的单元格
- java - 如何解决 Android 中已弃用的 View 方法?
- pointers - Go 指针交换问题
- r - 如何在r中将文本变量转换为数字变量