效果如图:
数据库格式:
思路:数据表这里是根据用户ID来匹配每个用户的好友列表,朋友ID,每个ID后面跟一个‘逗号’(,),可以储存多个好友,
thinkphp取出数据库数据,再把friends字段的值打散成数组,再根据用户ID来检索所需要的数据。
上面是拿出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’]`的数组中,这里就已经完成了首字母分类了。
这下面一段,是查询我数据表对应用户的资料,可以修改成自己的逻辑。
$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;}最后,本人学习才不久,望勿见怪,这里也只是作笔记存放而已。