效果如图:
数据库格式:
思路:数据表这里是根据用户ID来匹配每个用户的好友列表,朋友ID,每个ID后面跟一个‘逗号’(,),可以储存多个好友,
thinkphp取出数据库数据,再把friends字段的值打散成数组,再根据用户ID来检索所需要的数据。
$mqlfind = Db::name('friends_list')->where('userid',$user)->find();
上面是拿出friends这个字段的值,
拿到这个值再进行处理!
下面是对这个值的相关处理操作:
1.首先把这个值打散成数组,然后遍历的时候,给每个
v
a
l
u
e
添
加
一
个
‘
(
k
e
y
)
‘
c
h
a
r
t
’
‘
,
‘
g
e
t
F
i
r
s
t
C
h
a
r
t
(
value添加一个`(key)‘chart’`,`getFirstChart(
value添加一个‘(key)‘chart’‘,‘getFirstChart(name);,chart的值为根据用户ID检索到的中文姓名(
n
a
m
e
‘
)
匹
配
的
首
字
母
,
并
返
回
首
字
母
(
‘
g
e
t
F
i
r
s
t
C
h
a
r
t
(
name`)匹配的首字母,并返回首字母(` getFirstChart(
name‘)匹配的首字母,并返回首字母(‘getFirstChart(name);),再根据自己用户数据表的数据添加其它值; 2. $data为数组,遍历第一步生成的数组
a
r
r
D
a
t
a
‘
,
‘
arrData`,`
arrData‘,‘val等于第一步中生成的
[‘chart’ =>
f
r
i
s
t
,
′
n
a
m
e
′
=
>
frist,'name' =>
frist,′name′=>name,‘user’ =>
v
a
l
u
e
,
′
h
e
a
d
i
m
g
′
=
>
D
b
:
:
n
a
m
e
(
′
u
s
e
r
′
)
−
>
w
h
e
r
e
(
′
u
s
e
r
′
,
value,'headimg' => Db::name('user')->where('user',
value,′headimg′=>Db::name(′user′)−>where(′user′,value)->value(‘headimg’)] , 这里
d
a
t
a
[
data[
data[val[‘chart’]][]=
v
a
l
‘
,
就
将
‘
val`,就将`
val‘,就将‘val插入键等于
$val[‘chart’]`的数组中,这里就已经完成了首字母分类了。
$array = explode(",",$mqlfind['friends']);
foreach ($array as $key => $value) {
$name = Db::name('user')->where('user',$value)->value('name');
$frist = getFirstChart($name);
$arrData[$key] = ['chart' =>$frist,'name' =>$name,'user' => $value,'headimg' => Db::name('user')->where('user',$value)->value('headimg')];
}
$list=[];
$data=[];
//给所有数组进行A-Z分类
foreach ($arrData as $K => $val) {
if (empty($data[ $val['chart']])) {
$data[$val['chart']]=[];
}
$data[$val['chart']][]=$val;
}
//按照键名排序
ksort($data);
return json(ajax($data,10030,'获取成功'));
这下面一段,是查询我数据表对应用户的资料,可以修改成自己的逻辑。
$arrData[$key] = ['chart' =>$frist,'name' =>$name,'user' => $value,'headimg' => Db::name('user')->where('user',$value)->value('headimg')];
返回首字母
/**
* 返回取汉字的第一个字的首字母
* @param [type] $str [string]
* @return [type] [strind]
*/
function getFirstChart($str){
if( empty($str) ){
return '';
}
$char=ord($str[0]);
if( $char >= ord('A') && $char <= ord('z') ){
return strtoupper($str[0]);
}
$s1=iconv('UTF-8','gb2312',$str);
$s2=iconv('gb2312','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<=-17418) return 'H';
if($asc>=-17417&&$asc<=-16475) return 'J';
if($asc>=-16474&&$asc<=-16213) return 'K';
if($asc>=-16212&&$asc<=-15641) return 'L';
if($asc>=-15640&&$asc<=-15166) return 'M';
if($asc>=-15165&&$asc<=-14923) return 'N';
if($asc>=-14922&&$asc<=-14915) return 'O';
if($asc>=-14914&&$asc<=-14631) return 'P';
if($asc>=-14630&&$asc<=-14150) return 'Q';
if($asc>=-14149&&$asc<=-14091) return 'R';
if($asc>=-14090&&$asc<=-13319) return 'S';
if($asc>=-13318&&$asc<=-12839) return 'T';
if($asc>=-12838&&$asc<=-12557) return 'W';
if($asc>=-12556&&$asc<=-11848) return 'X';
if($asc>=-11847&&$asc<=-11056) return 'Y';
if($asc>=-11055&&$asc<=-10247) return 'Z';
return null;
}
最后,本人学习才不久,望勿见怪,这里也只是作笔记存放而已。