一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Redis - Redis 緩存實現存儲和讀取歷史搜索關鍵字的操作方法

Redis 緩存實現存儲和讀取歷史搜索關鍵字的操作方法

2021-02-21 17:35相逢不晚何必匆匆 Redis

這篇文章主要介紹了Redis 緩存實現存儲和讀取歷史搜索關鍵字,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

 

一、本案例涉及知識

  1.  Layui
  2. Redis
  3. Vue.js
  4. jQuery
  5. Ajax

 

二、效果圖

Redis 緩存實現存儲和讀取歷史搜索關鍵字的操作方法

 

三、功能實現

(一)使用 Layui 的樣式構建頁面

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
<!DOCTYPE html>
<html>
<head>
 <meta charset="utf-8">
 <title>Redis應用 - 搜索歷史</title>
 <!-- 引入 Layui CSS -->
 <link rel="stylesheet" href="css/layui.css" rel="external nofollow" >
</head>
<body>
<div class="layui-form" style="width: 50%;margin-top: 20px;" id="app">
 <div class="layui-form-item">
  <label class="layui-form-label"></label>
  <div class="layui-input-block">
   <input type="text" class="layui-input">
  </div>
 </div>
 <div class="layui-form-item">
  <label class="layui-form-label"></label>
  <div class="layui-input-block">
   <button class="layui-btn">搜索</button>
  </div>
 </div>
 <div class="layui-form-item">
  <label class="layui-form-label"></label>
  <div class="layui-input-block">
   搜索歷史
  </div>
 </div>
 <div class="layui-form-item">
  <label class="layui-form-label"></label>
  <div class="layui-input-block">
   <span class="layui-badge layui-bg-gray" style="margin-left: 5px;">PHP</span>
   <span class="layui-badge layui-bg-gray" style="margin-left: 5px;">JavaScript</span>
  </div>
 </div>
</div>
<!-- 引入 jQuery -->
<script src="js/jquery-3.5.1.min.js"></script>
<!-- 引入 Layui JS -->
<script src="js/layui.js"></script>
<!-- 引入 Vue.js -->
<script src="js/vue.min.js"></script>
</body>
</html>

(二)點擊搜索時儲存本次搜索的關鍵字

給文本框添加 Vue 雙向綁定

?
1
<input type="text" class="layui-input" v-model="keyword">

給搜索按鈕添加點擊事件

?
1
<button class="layui-btn" @click="addHistory()">搜索</button>
?
1
2
3
4
5
6
7
8
9
10
11
<script type="text/javascript">
 var vm = new Vue({
  el: "#app",
  data: {
   keyword: ""
  },
  methods: {
   addHistory: function () {}
  }
 });
</script>

當文本框被輸入內容后,輸入的內容將綁定給 Vue 中 datakeyword 字段。

點擊搜索按鈕時,觸發 addHistory() 函數,此函數將輸入的內容發送給 PHP ,PHP 操作 Redis 將內容進行緩存

addHistory() 函數中:

?
1
2
3
4
5
6
7
8
9
10
11
addHistory: function () {
 $.ajax({
  url: "history.php",
  type: "GET",
  data: {type: 'add', keyword: this.keyword},
  success: function () {
    // 請求成功后刷新本頁面
   window.location.reload();
  }
 });
}

data 中傳值兩個字段,type 表示本次請求的類型,其中 add 代表往緩存中添加關鍵字,read 代表從緩存中讀取關鍵字。

history.php 中:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
<?php
$redis = new Redis();
$con = $redis->connect('localhost', 6379);
if (!$con) {
 echo 'Redis連接失敗';
}
// 接收請求類型參數的值
$type = $_GET['type'];
// 模擬用戶的id,因為每個用戶搜索的內容不同,需要進行區分
$user_id = 'user-1';
// 如果請求類型為添加
if ($type == 'add') {
    // 接收輸入的關鍵字
 $keyword = $_GET['keyword'];
 // 讀取當前用戶隊列中存儲的關鍵字個數,即隊列的長度
 $len = $redis->llen($user_id);
 // 如果個數大于等于 5 個,則刪除最開始搜索的關鍵字,加入最新搜索的關鍵字
 if ($len >= 5) {
    // 移除隊列左側的第一個關鍵字
  $redis->lPop($user_id);
  // 在隊列右側加入新的關鍵字
  $redis->rPush($user_id, $keyword);
 } else {
    // 不多于 5 個直接在隊列右側加入新的關鍵字
  $redis->rPush($user_id, $keyword);
 }
}

(三)讀取并展示歷史搜索的關鍵字

第二步中加入了當請求添加緩存成功后會刷新頁面的代碼,

?
1
window.location.reload();

在這個基礎上,我們希望刷新的同時執行另一個 Ajax 請求從 PHP 中操作 Redis 將所有的歷史搜索關鍵字讀取出來并在頁面中展示。

所以在 Vue 中加入頁面加載完成自動調用getHistory()函數:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
methods: {
 getHistory: function () {},
 addHistory: function () {
  $.ajax({
   url: "history.php",
   type: "GET",
   data: {type: 'add', keyword: this.keyword},
   success: function () {
    window.location.reload();
   }
  });
 }
},
// 頁面加載完成自動調用 getHistory()
created () {
 this.getHistory();
}

getHistory()函數中:

?
1
2
3
4
5
6
7
8
9
10
11
getHistory: function () {
 $.ajax({
  url: "history.php",
  type: "GET",
  data: {type: 'read'},
  success: function (r) {
    // JSON.parse(r) 將讀取到的 json 字符串轉為 json 對象
   vm.history = JSON.parse(r);
  }
 });
}

data 中傳值一個字段,read 代表從緩存中讀取關鍵字,請求成功后將返回的結果賦值給 Vue 中 datahistory 字段。

history.php 中添加讀取操作:

?
1
2
3
4
5
6
7
// 如果請求類型為讀取
if ($type == 'read') {
    // 從隊列左側依次取出 5 個關鍵字
 $history = $redis->lrange($user_id, 0, 4);
 // 轉為 json 格式的數據并輸出到頁面中供 Ajax 使用
 echo json_encode($history, JSON_UNESCAPED_UNICODE);
}

將讀取到的數據成功賦值給 Vue 中 datahistory 字段后,頁面中即可將數據循環輸出展示:

?
1
<span class="layui-badge layui-bg-gray" v-for="item in history" style="margin-left: 5px;">{{item}}</span>

連貫過程為:用戶輸入關鍵字并點擊搜索按鈕,Ajax 請求 PHP 操作 Redis 進行數據緩存且緩存成功后刷新頁面,頁面刷新后自動調用函數執行 Ajax 請求 PHP 操作 Redis 進行緩存數據的讀取并返回于頁面中同時進行渲染展示。

到此這篇關于Redis 緩存實現存儲和讀取歷史搜索關鍵字的文章就介紹到這了,更多相關Redis 緩存實現存儲和讀取關鍵字內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/ZhangJiWei_2019/article/details/110924696

延伸 · 閱讀

精彩推薦
  • RedisRedis全量復制與部分復制示例詳解

    Redis全量復制與部分復制示例詳解

    這篇文章主要給大家介紹了關于Redis全量復制與部分復制的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Redis爬蟲具有一定的參考學習...

    豆子先生5052019-11-27
  • Redisredis實現排行榜功能

    redis實現排行榜功能

    排行榜在很多地方都能使用到,redis的zset可以很方便地用來實現排行榜功能,本文就來簡單的介紹一下如何使用,具有一定的參考價值,感興趣的小伙伴們...

    乘月歸5022021-08-05
  • RedisRedis如何實現數據庫讀寫分離詳解

    Redis如何實現數據庫讀寫分離詳解

    Redis的主從架構,能幫助我們實現讀多,寫少的情況,下面這篇文章主要給大家介紹了關于Redis如何實現數據庫讀寫分離的相關資料,文中通過示例代碼介紹...

    羅兵漂流記6092019-11-11
  • Redisredis中如何使用lua腳本讓你的靈活性提高5個逼格詳解

    redis中如何使用lua腳本讓你的靈活性提高5個逼格詳解

    這篇文章主要給大家介紹了關于redis中如何使用lua腳本讓你的靈活性提高5個逼格的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具...

    一線碼農5812019-11-18
  • Redisredis 交集、并集、差集的具體使用

    redis 交集、并集、差集的具體使用

    這篇文章主要介紹了redis 交集、并集、差集的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友...

    xiaojin21cen10152021-07-27
  • RedisRedis的配置、啟動、操作和關閉方法

    Redis的配置、啟動、操作和關閉方法

    今天小編就為大家分享一篇Redis的配置、啟動、操作和關閉方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧 ...

    大道化簡5312019-11-14
  • RedisRedis 事務知識點相關總結

    Redis 事務知識點相關總結

    這篇文章主要介紹了Redis 事務相關總結,幫助大家更好的理解和學習使用Redis,感興趣的朋友可以了解下...

    AsiaYe8232021-07-28
  • Redis詳解Redis復制原理

    詳解Redis復制原理

    與大多數db一樣,Redis也提供了復制機制,以滿足故障恢復和負載均衡等需求。復制也是Redis高可用的基礎,哨兵和集群都是建立在復制基礎上實現高可用的...

    李留廣10222021-08-09
主站蜘蛛池模板: 男男互操文 | 色视频久久 | 欧美精品黑人巨大在线播放 | 我与旗袍老师疯狂床震 | 男人天堂资源网 | 日韩久久中文字幕 | 精品无码国产AV一区二区三区 | 九九九九九九伊人 | se01在线看片 | 性夜夜春夜夜爽AA片A | 亚洲欧美一区二区久久 | 三级黄色片在线免费观看 | 久久综合中文字幕佐佐木希 | 日本视频中文字幕 | 2012年中文字幕在线看 | 按摩院已婚妇女中文字幕 | 免费看一级毛片 | chanelpreston欧美网站 | 扒开斗罗美女了的胸罩和内裤漫画 | 国产日韩欧美在线一区二区三区 | 北条麻妃黑人正在播放 | 精品国产国偷自产在线观看 | 福利视频一区青娱 | 欧美坐爱 | 国产第一页在线视频 | 日本久久热 | 青青草国产免费国产是公开 | japanesepooping脱粪| 免费免费啪视频在线观播放 | 国产免费看黄的私人影院 | 成人在线日韩 | 欧美亚洲国产另类 | 日本ccc三级 | 四虎麻豆 | 四虎成人免费大片在线 | 卫生间被教官做好爽HH视频 | 精品蜜臀AV在线天堂 | 免费看黄色片网站 | 96日本xxxxxxxxx70 95在线观看精品视频 | 午夜小视频免费 | 暖暖 免费 高清 日本 在线1 |