繁体   English   中英

从数组中删除关联的键/值对(嵌套)

[英]Removing an associated key/value pair from array (nested)

我有两个函数可以将删除参数添加到查询字符串中。 “add_query_params”(感谢本论坛)运行良好,我现在可以向相同类型的查询字符串添加多个标签。

例如

http://example.com?tags[]=flowers&tags[]=shrubs&category[]=garden

如您所见,我可以添加多个相同的参数,我也使用查询过滤器很好地查询这些参数。

然而,我最新的问题是简单地删除单个标签类型而不影响查询字符串的其余部分。 然后我将在没有删除标签的情况下重建查询。

昨天有人好心地帮助了我,但这会删除所有标签键值,而不仅仅是指定的标签。

因此,如果我要从上述 URL 中删除 say $tags[]shrubs ,它实际上会同时删除tag[]shrubs AND $tags[]flowers

这对于我正在设计的过滤系统显然不是很直观。 我想知道的是如何仅删除单个键值对并保持其他键对不变。

这是我的辅助功能

//Accept a param array which passthrough through tag type eg category/tag and value
function remove_query_params(array $params = [])
{
    //Set to array
    $existingParams = [];

    $existingParams = request()->query();

    foreach($params as $key=>$value){

        if (isset($existingParams[$value])) {
            unset($existingParams[$value]);
        }
    }


    $query = http_build_query($existingParams);

    return url()->current() . '?' . $query;
}

//Need to return: user removes tag from filter in blade, URL recontructs without the passed through tag value
//Before
//http://example.com?tags[]=flowers&tags[]=shrubs&category[]=garden

//After
//http://example.com?tags[]=flowers&category[]=garden

这不起作用,如果我将 $value 更改为 $key 那么它会起作用,但它会删除相同类型的所有键,而不是我想要的行为。

我通过刀片模板中的调用激活此行为,这形成了一个 href

//Pass through parameter type and parameter value
{{remove_query_params(['category' => $category->id]) }}

有没有人知道我下一步要去哪里?#

谢谢和手指交叉我不远了:)

亚当

我希望这个解决方案能帮助你:

<?php
function remove_query_params(array $params = [])
{
    //Set to array
    $existingParams = [
        'tags' => [
            'aaaa',
            'bbbb'
        ],
        'category' => 'ccc'
    ];

    // go trough all parameters
    foreach ($existingParams as $key1 => $value1) {
        // go to the parameters, which need to be deleted
        foreach ($params as $key2 => $value2) {
            // only if the keys equals, do something
            if ($key1 === $key2) {
                // if the param is an array
                if (is_array($value1)) {
                    foreach ($value1 as $k => $v) {
                        // if the elements to delete are an array
                        if (is_array($value2)) {
                            foreach ($value2 as $b => $r) {
                                if ($v == $r) {
                                    unset($existingParams[$key1][$k]);
                                }
                            }
                        } else {
                            if ($v == $value2) {
                                unset($existingParams[$key1][$k]);
                            }
                        }
                    }
                } else {
                    if (isset($existingParams[$key2])) {
                        unset($existingParams[$key2]);
                    }
                }
            }
        }
    }
    $query = http_build_query($existingParams);
    return $query;
}

echo remove_query_params(['tags' => 'aaaa']);
echo "\n";
echo remove_query_params(['tags' => ['aaaa', 'bbbb']]);
echo "\n";
echo remove_query_params(['category' => 'ccc']);
echo "\n";

tags不是关联的数组。 它只是一个字符串列表。 另外,看看$existingParams = request()->query(); 它不是tags数组。 它是一个包含它的对象。 这就是为什么当您使用$key它可以工作但会删除所有内容,因为$keytags 因此,在您的支票$existingParams['tags']应检查shrubs值。 in_array就是您在这种情况下要查找的内容。

希望这能解决你的问题。我只是提供了核心功能来以某种方式完成工作

$query = "tags[]=flowers&tags[]=shrubs&category[]=garden";
echo (remove_query_params( [ 'tags' => 'shrubs' ], $query ));


function remove_query_params(array $params = [], $query )
{
    parse_str( $query, $existingParams );
    
    $existing_keys = array_keys( $existingParams);
    
    foreach($params as $key=>$value){
        if( in_array( $key, $existing_keys ) ){
           foreach ($existingParams[$key] as $param_key => $param_value) {
               if( $param_value == $value ){
                unset( $existingParams[$key][$param_key] );
               }
           }
        }
    }
    $query = http_build_query($existingParams);
    return $query;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM