$list1 = $b->where("gwstatus=1 and gwname like '%$zm%'")->order("time desc")->select();//
查询
$narr =array();
foreach( $list1 as $key => $val){
$ct2 = explode(" ",$val['gwname']);//
获取标题拆分成数组。
$szm=strtolower(substr($ct2[1],0,1)); //
获取首字母 并且小写
if($ct2[0]=="The" && $szm==$zm){//如果第一个字符是 The 并且第二个字母首字母
和提交的相同,这里 The
区分大小写。
$narr[] = $val; //
写入数组
}
}
}else{ //处理首字母是 T
的时候
,不希望第一个字数 The
的显示在列表里。
$list1 = $b->where("gwstatus=1 and gwname like '$wzm'")->order("time desc")->select();
foreach( $list1 as $key => $val){
$ct2 = explode(" ",$val['gwname']);
if($ct2[0]=="The"){
$unnarr[] = $key;//
获取符合条件的,要去掉的内容的数组标号。
}
}
}
$list = $b->where("gwstatus=1 and gwname like '$wzm'")->order("time desc")->select();//正
常的查询。
if($zm=="t"){//处理当首字母是 t
的时候 ,去掉上面查询得到的内容,也就是如果是 The
的时候 按 T
不显示。
foreach($unnarr as $uval){
unset($list[$uval]);
}
}else{//按下的不是 t 的时候,要把第二个首字母符合的内容添加到正常查询的数组中。
if(!empty($narr) && !empty($list)){//带 The
的符合条件正常 本身也不空的时候。
$list = array_merge($narr,$list);//
合并数组。
}else if(empty($list)){//正常查询为空。则看是否有带 The
开头的,有则合并
$list=array();
$list = array_merge($narr,$list);
}
}
if($list){
$this->ajaxReturn($list,'success',1);
}else{
$this->error("Bestiary not found.");
}
}