THINKPHP_(1)_修改TP源码,支持对中文字符串按拼音进行排序。

问题:TP从服务器数据中取出的collection数据,当进一步在网页中进行分页显示时,需要调用order函数,实现类似如下图的排序。

 

当点击页面中的相关内容时,实现对服务器数据进行重排,就要调用TP编写的order函数。

但是,上述属性中包括int属性,包括中文字符串属性,我们希望按单位名称和单位简称按汉字拼音进行排序,如何修改。

解决方法

将TP的order函数源码从(order函数位于think-helper\src\Collection.php文件中)

    public function order(string $field, string $order = 'asc')
    {
        return $this->sort(function ($a, $b) use ($field, $order) {
            
                $fieldA = $a[$field] ?? null;
                $fieldB = $b[$field] ?? null;

                return 'desc' == strtolower($order) ? $fieldB > $fieldA : $fieldA > $fieldB;
            
        });
    }       

改为:

    public function order(string $field, string $order = 'asc')
    {
        return $this->sort(function ($a, $b) use ($field, $order) {
            //添加对中文的支持。
            //xiaojie add代码,添加对中文的支持。
            $fieldA = $a[$field] ?? null;
            $fieldB = $b[$field] ?? null;
            //注意,如果取出的$fieldA是数字,就不能用preg_match。所以,应该加上一个字符串判断类型。因为有些时候会对数字进行排序。

            if (isset($fieldA) && isset($fieldB) && is_string($fieldA) &&is_string($fieldB) && preg_match("/[\x7f-\xff]/", $fieldA)){ //如果字段内容中有中文。
                $coll = collator_create( 'zh-CN' );
                $res  = collator_compare( $coll, $fieldA, $fieldB );
                return 'desc' == strtolower($order) ? $res<0 : $res>0;
            }
            else{
//                $fieldA = $a[$field] ?? null;
//                $fieldB = $b[$field] ?? null;

                return 'desc' == strtolower($order) ? $fieldB > $fieldA : $fieldA > $fieldB;
            }
        });
    }

即可。

 

posted @ 2021-05-31 19:36  秦皇汉武  阅读(268)  评论(0编辑  收藏  举报