1 首先先查询数据
public function index(){
$brand = StoreBrand::where('is_show',1)->order('sort desc,id desc')->where('pid','<>',0)->select()->toArray();
$res = $this->getDistrict($brand); //数组带入查询并排列
dump($res) ;
}
public function getDistrict( $areaData )
{
// 按照首字母拼音排序
$district = array();
foreach( $areaData as $name )
{
//取出第一个汉字的首字母(**需要排列的名称,我这里是cate_name**)
//获取首字母ABCD
$snameFirstChar = $this->_getFirstCharter($name['cate_name']);
//以这个首字母作为key// value值不变
$district[$snameFirstChar][] =$name;
}
ksort($district);//排序
return $district;
}
/**
*字母排序
*/
public function _getFirstCharter($str)
{
if(empty($str))
{
return '';
}
$fchar=ord($str{0});
if($fchar>=ord('A')&&$fchar<=ord('z'))
return strtoupper($str{0});
$s1=iconv('UTF-8','GBK',$str);
$s2=iconv('GBK','UTF-8',$s1);
$s=$s2==$str?$s1:$str;
$asc=ord($s{0})*256+ord($s{1})-65536;
if($asc>=-20319&&$asc<=-20284) return 'A';
if($asc>=-20283&&$asc<=-19776) return 'B';
if($asc>=-19775&&$asc<=-19219) return 'C';
if($asc>=-19218&&$asc<=-18711) return 'D';
if($asc>=-18710&&$asc<=-18527) return 'E';
if($asc>=-18526&&$asc<=-18240) return 'F';
if($asc>=-18239&&$asc<=-17923) return 'G';
if($asc>=-17922&&$asc<=