Php 使用createUrl()时,Yii 2正在排序名称的开头添加连字符

Php 使用createUrl()时,Yii 2正在排序名称的开头添加连字符,php,yii2,Php,Yii2,我使用的是Yii 2,我创建了一个and系统,并具有以下代码: 以下是通用代码: $sql = $this->db->createCommand("SELECT COUNT(*) FROM some_table WHERE some_id=:some_id"); $sql->bindValue(':some_id', $this->some_id); $count = $sql->queryScalar(); $dataProvider = new SqlData

我使用的是
Yii 2
,我创建了一个and系统,并具有以下代码:

以下是通用代码:

$sql = $this->db->createCommand("SELECT COUNT(*) FROM some_table WHERE some_id=:some_id");
$sql->bindValue(':some_id', $this->some_id);
$count = $sql->queryScalar();

$dataProvider = new SqlDataProvider([
    'sql' => 'SELECT * FROM some_table WHERE some_id=:some_id',
    'params' => [':some_id' => $this->some_id],
    'totalCount' => $count,
    'sort' => [
        'attributes' => [
            'sort_way_1' => [
                'asc' => ['col_1' => SORT_DESC, 'col_2' => SORT_ASC, 'col_3' => SORT_ASC],
                'desc' => ['col_1' => SORT_DESC, 'col_2' => SORT_DESC, 'col_3' => SORT_DESC],
                'default' => SORT_DESC,
                'label' => 'Sort Way 1',
            ],
            'sort_way_2' => [
                'asc' => ['col_1' => SORT_DESC, 'col_4' => SORT_ASC, 'col_3' => SORT_ASC],
                'desc' => ['col_1' => SORT_DESC, 'col_4' => SORT_DESC, 'col_3' => SORT_DESC],
                'default' => SORT_DESC,
                'label' => 'Sort Way 2',
            ],
            'sort_way_3' => [
                'asc' => ['col_1' => SORT_DESC, 'col_5' => SORT_ASC, 'col_3' => SORT_ASC],
                'desc' => ['col_1' => SORT_DESC, 'col_5' => SORT_DESC, 'col_3' => SORT_DESC],
                'default' => SORT_DESC,
                'label' => 'Sort Way 3',
            ],
            'sort_way_4' => [
                'asc' => ['col_1' => SORT_DESC, 'col_6' => SORT_ASC, 'col_3' => SORT_ASC],
                'desc' => ['col_1' => SORT_DESC, 'col_6' => SORT_DESC, 'col_3' => SORT_DESC],
                'default' => SORT_DESC,
                'label' => 'Sort Way 4',
            ],
        ],
        'enableMultiSort' => false,
        'defaultOrder' => ['sort_way_1' => SORT_DESC],
    ],
    'pagination' => [
        'defaultPageSize' => $this->per_page,
        'pageSize' => $this->per_page,
        'pageSizeLimit' => [5,100],
        'pageSizeParam' => 'per_page',
        'totalCount' => $count,
    ],
]);
现在,对于我的排序链接,我尝试使用该方法创建URL,除了在URL中排序属性名称的开头附加一个
-
(第一个排序方法除外)之外,一切正常

示例:

http://example.com/some_dir/?page=1&sort=sort_way_1 (good)
http://example.com/some_dir/?page=1&sort=-sort_way_2 (bad)
然后我试着用这个做,但我得到了同样的结果

我仔细研究了一下代码,在
sort.php
方法中找到了以下代码:

这似乎是附加连字符的罪魁祸首,但我不确定它为什么这样做,或者为什么不将其添加到第一个排序属性


有没有人知道更多关于这件事的信息,或者如何避开它?与附加的连字符一样,请求的排序方法返回为无效。

是否要同时按两种方式(升序和降序)进行排序以进行排序?@Marek是的,这应该是一个选项。但是如果他们希望排序不同于默认值,那么URL中不包括
&direction=
吗?不,它使用连字符来区分要排序的方向:
sort=-sort\u way\u 2
是递减的,
sort=sort\u way\u 2
是递增的。如果你不喜欢这样,你只能靠自己,你必须重新实现它。我不知道这有多困难。这是默认行为。ASC-不带连字符,DESC-带连字符。到底是什么问题?你想用什么来代替它?在这种情况下靠什么?或者在更改订单方向时引发异常?但后者表明代码中存在错误。@arogachev这只是一种奇怪的方式而已。不能说我以前见过这种方式,大多数站点/软件都是通过使用asc/desc作为单独的参数来实现的。没什么大不了的,如果有必要,我可以解决它。:)
foreach ($directions as $attribute => $direction) {
    $sorts[] = $direction === SORT_DESC ? '-' . $attribute : $attribute;
}