[TOC]
## 檢索出除自己外呢稱含有關鍵字的用戶
```
$where = array(
'username' => array('LIKE', '%' . $keyword . '%'),
'uid' => array('NEQ', session('uid'))
);
```
## 互相關注組合條件
```
$db = M('follow');
$sql = '(SELECT `follow` FROM `hd_follow` WHERE `follow` = ' . $v['uid'] . ' AND `fans` = ' . session('uid') . ') UNION (SELECT `follow` FROM `hd_follow` WHERE `follow` = ' . session('uid') . ' AND `fans` = ' . $v['uid'] . ')';
$mutual = $db->query($sql);
```
>完整代碼:
```
/**
* 重組結果集得到是否互相關注與是否已關注
* @param [Array] $result [需要處理的結果集]
* @return [Array] [處理完成后的結果集]
*/
Private function _getMutual ($result) {
if (!$result) return false;
$db = M('follow');
foreach ($result as $k => $v) {
//是否互相關注
$sql = '(SELECT `follow` FROM `hd_follow` WHERE `follow` = ' . $v['uid'] . ' AND `fans` = ' . session('uid') . ') UNION (SELECT `follow` FROM `hd_follow` WHERE `follow` = ' . session('uid') . ' AND `fans` = ' . $v['uid'] . ')';
$mutual = $db->query($sql);
if (count($mutual) == 2) {
$result[$k]['mutual'] = 1;
$result[$k]['followed'] = 1;
} else {
$result[$k]['mutual'] = 0;
//未互相關注是檢索是否已關注
$where = array(
'follow' => $v['uid'],
'fans' => session('uid')
);
$result[$k]['followed'] = $db->where($where)->count();
}
}
return $result;
}
```
## 格式化搜索關鍵字(加紅搜索關鍵字)
```
{$v.username|str_replace=$keyword, '<font style="color:red">' . $keyword . '</font>', ###}
<a href="">{$v.username|str_replace=$keyword, '<font style="color:red">' . $keyword . '</font>', ###}</a>
```
## 搜索找人后臺處理
```
/**
* 搜索找人
*/
Public function sechUser () {
$keyword = $this->_getKeyword();
if ($keyword) {
//檢索出除自己外呢稱含有關鍵字的用戶
$where = array(
'username' => array('LIKE', '%' . $keyword . '%'),
'uid' => array('NEQ', session('uid'))
);
$field = array('username', 'sex', 'location', 'intro', 'face80', 'follow', 'fans', 'weibo', 'uid');
$db = M('userinfo');
//導入分頁類
import('ORG.Util.Page');
$count = $db->where($where)->count('id');
$page = new Page($count, 20);
$limit = $page->firstRow . ',' . $page->listRows;
$result = $db->where($where)->field($field)->limit($limit)->select();
//重新組合結果集,得到是否已關注與是否互相關注
$result = $this->_getMutual($result);
//分置搜索結果到視圖
$this->result = $result ? $result : false;
//頁碼
$this->page = $page->show();
}
$this->keyword = $keyword;
$this->display();
}
```
### 返回搜索關鍵字
```
Private function _getKeyword () {
return $_GET['keyword'] == '搜索微博、找人' ? NULL : $this->_get('keyword');
}
```
### 檢查是否互相關注
```
/**
* 重組結果集得到是否互相關注與是否已關注
* @param [Array] $result [需要處理的結果集]
* @return [Array] [處理完成后的結果集]
*/
Private function _getMutual ($result) {
if (!$result) return false;
$db = M('follow');
foreach ($result as $k => $v) {
//是否互相關注
$sql = '(SELECT `follow` FROM `hd_follow` WHERE `follow` = ' . $v['uid'] . ' AND `fans` = ' . session('uid') . ') UNION (SELECT `follow` FROM `hd_follow` WHERE `follow` = ' . session('uid') . ' AND `fans` = ' . $v['uid'] . ')';
$mutual = $db->query($sql);
if (count($mutual) == 2) {
$result[$k]['mutual'] = 1;
$result[$k]['followed'] = 1;
} else {
$result[$k]['mutual'] = 0;
//未互相關注是檢索是否已關注
$where = array(
'follow' => $v['uid'],
'fans' => session('uid')
);
$result[$k]['followed'] = $db->where($where)->count();
}
}
return $result;
}
```
## 模板顯示搜索數據
```
<if condition="isset($result)">
<div id='content'>
<if condition='$result'>
<div class='view_line'>
<strong>用戶</strong>
</div>
<ul>
<foreach name='result' item='v'>
<li>
<dl class='list-left'>
<dt>
<img src="
<if condition='$v["face80"]'>
__ROOT__/Uploads/Face/{$v.face80}
<else/>
__PUBLIC__/Images/noface.gif
</if>" width='80' height='80'/>
</dt>
<dd>
<a href="">{$v.username|str_replace=$keyword, '<font style="color:red">' . $keyword . '</font>', ###}</a>
</dd>
<dd>
<i class='icon icon-boy'></i>
<span>
<if condition='$v["location"]'>
{$v.location}
<else/>
該用戶未填寫所在地
</if>
</span>
</dd>
<dd>
<span>關注 <a href="">{$v.follow}</a></span>
<span class='bd-l'>粉絲 <a href="">{$v.fans}</a></span>
<span class='bd-l'>微博 <a href="">{$v.weibo}</a></span>
</dd>
</dl>
<dl class='list-right'>
<if condition='$v["mutual"]'>
<dt>互相關注</dt>
<dd class='del-follow' uid='{$v.uid}' type='1'>移除</dd>
<elseif condition='$v["followed"]' />
<dt>√ 已關注</dt>
<dd class='del-follow' uid='{$v.uid}' type='1'>移除</dd>
<else/>
<dt class='add-fl' uid='{$v.uid}'>+ 關注</dt>
</if>
</dl>
</li>
</foreach>
</ul>
<div style="text-align:center;padding:20px;">{$page}</div>
<else/>
<p style='text-indent:7em;'>未找到與<strong style='color:red'>{$keyword}</strong>相關的用戶</p>
</if>
</div>
</if>
```
- Layer無刷新不跳轉彈框提示信息
- 整合ThinkPHP+實用代碼
- TP整合Layer插件實現無刷新
- 自定義助手函數
- 添加信息失敗后不跳轉
- 三種無限級分類
- TP常用代碼
- 自定義公共函數
- TP模型管理專題
- TP模型管理之添加模型
- sfox_newmodel.sql
- TP模型管理之刪除模型
- TP模型管理之編輯模型
- TP模型管理之字段添加
- sfox_newmodel.sql_edit
- layer_hplus.js_edit
- TP模型管理之字段刪除
- TP模型管理之字段編輯
- TP模型管理之預覽模型
- TP模型管理之公共函數
- layer_hplus.js_修訂一
- TP模型管理之預覽模型靜態頁
- 后臺內容管理系統
- 分類樹顯示
- 內容列表顯示
- 信息發布
- 編輯信息
- layer_hplus.js
- myJs第一版
- myJs第二版
- myJs第三版
- myJs第四版
- TP5插件用法
- Datatables
- WebUploader
- bootstrap-fileinput
- UEditor
- 簡單調用
- 路徑問題
- 跨域多圖上傳
- 跨域單圖上傳
- UEditor圖片跨域上傳解決方案
- 定制工具欄圖標
- ajaxFileUpload
- LayUI
- 圖片上傳
- layui分頁
- 搜索頁
- 搜索優化及刪除
- Uploadify
- TP5前端應用
- 靜態首頁
- 前臺首頁功能實現
- 自定義標簽庫
- 前臺模板繼承應用
- 首頁自定義標簽改進
- 文章內容頁
- 自定義標簽改進
- 自定義標簽修正
- 圖片等比例自動縮放
- 后臺權限管理
- 角色管理
- 規則管理
- 權限設置
- 會員管理
- 權限管理
- 前臺登錄注冊功能
- 注冊登錄
- 阿里大于手機注冊
- 阿里大于升級阿里云短信服務
- 自動登錄完成
- PHP異位或加密實現自動登陸
- 微信開發
- 分享接口
- 靜態頁面實現微信分享
- 動態頁微信分享
- 頁面靜態化
- 1-全站靜態化前期配置
- 2-鏈接地址靜態化
- TP5常用片段代碼
- 加載靜態資源路徑與常量
- thinkphp5預定義常量
- 刪除某文件夾的內容
- 解壓插件包
- 異步提交插件
- 其他功能
- 背景音樂
- 手機訪問PC網站自動跳轉到手機網站代碼
- 手機微信音樂MP3播放器
- 后盾之網頁背景音樂
- 播放器寬度自適應
- 前臺首頁數據調用
- 視頻列表
- 搜索分頁
- H5解決蘋果(IOS)不能自動播放音樂
- 清空緩存
- 文件處理常識
- 刪除路徑下的所有文件夾和文件
- 一鍵清空緩存
- 評論留言
- 格式化時間
- 替換微博內容的URL地址@用戶與表情
- PHP正則理解
- jQuery評論插件
- TP空操作
- TP路由
- 跨域訪問
- 設置請其頭允許跨域請求
- 模板前臺判斷手機訪問跳轉手機網址代碼
- PHP遍歷一個文件夾下所有文件和子文件夾
- PHP獲取視頻的第一幀與時長
- TP5數據庫
- 鏈式操作原理
- update替換字段部分內容
- 后臺開發
- 后臺登錄頁居中顯示
- TP5自帶驗證碼
- JS & JQuery專題
- 二級城市聯動菜單
- 模板引擎
- 混合模板編譯
- 黃永成TP微博開發
- 消息推送
- memcache安裝
- 插件開發
- 插件介紹
- 插件鉤子
- 淺談初步理解鉤子
- 插件鉤子(hooks)分析
- 插件鉤子簡單理解
- 控制器調用插件
- 鉤子通用處理函數
- 插件基類代碼
- 插件測試代碼
- 淺談鉤子與插件
- 技術綜合
- 常用代碼
- PHP
- 56個PHP開發常用代碼片段(上)
- 56個PHP 開發常用代碼片段(中)
- 56個PHP 開發常用代碼片段(下)
- sublime text安裝自動補全注釋的插件
- 影音視頻開發
- 視頻
- H5視頻直播掃盲
- 音樂
- 語音
- PHP實現語音播報功能
- MUI
- 窗體操作