如何利用layim實現歷史記錄的初始化(附程式碼)

不言
發布: 2023-04-03 22:00:02
原創
5183 人瀏覽過

這篇文章帶給大家的內容是關於如何利用layim實現歷史記錄的初始化(附程式碼),有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

語言:PHP layui
沒有使用本地緩存,全部都是後台介面的資料

在做工單系統的時候,客戶要求必須要像QQ聊天一樣。我這多年根深蒂固的老phper,直接想起來layim。但是在遍歷工單歷史消息的時候出現了一些小問題,經過一天的熟悉終於弄出來,下面就分享一下自己的程式碼,順便做個記錄。
PS:我不是專業前端,方法用的不好,不要噴哈
- 首先是配置layim,就是官方文件的配置。

layim.config({
                        init: { }
                        ,voice:false
                        ,brief:false//是否简约模式,简约模式没有关闭按钮
                    });
登入後複製

這裡要注意一個地方,就是【簡約模式】是沒有關閉按鈕的。如果你需要關閉按鈕,又不想有列表,可以用css去除掉。

.layui-layim{
            display: none;
        }
登入後複製

接下來就是遍歷歷史訊息了

// 清空所有本地缓存消息
localStorage.clear();
// 先打开窗口
 layim.chat({
 name: '专家答疑'
      ,type: 'friend'
       ,avatar: '//tva3.sinaimg.cn/crop.0.0.180.180.180/7f5f6861jw1e8qgp5bmzyj2050050aa8.jpg'
       ,id: question_id
     });
// 获取历史消息
$.ajax({
url:"{:url('meet/get_init_msg')}",
type:"post",
data:{question_id:question_id},
dataType:"json",
success:function (data) {
if(data.length > 0){
for (var i in data){
layim.getMessage({
username: "专家答疑" //消息来源用户名
      ,avatar: "http://tp1.sinaimg.cn/1571889140/180/40030060651/1" //消息来源用户头像
      ,id: data[i]['question_id']//消息的来源ID(如果是私聊,则是用户id,如果是群聊,则是群组id)
      ,type: "friend" //聊天窗口来源类型,从发送消息传递的to里面获取
      ,content: data[i]['content'] //消息内容
      ,cid: 0 //消息id,可不传。除非你要对消息进行一些操作(如撤回)
      ,mine: true //是否我发送的消息,如果为true,则会显示在右方
      ,fromid: data[i]['user_id'] //消息的发送者id(比如群组中的某个消息发送者),可用于自动解决浏览器多窗口时的一些问题
      ,timestamp: data[i]['addtime'] * 1000 //服务端时间戳毫秒数。注意:如果你返回的是标准的 unix 时间戳,记得要 *1000
      });
layim.getMessage({
             username: "专家答疑" //消息来源用户名
             ,avatar: "//tva3.sinaimg.cn/crop.0.0.180.180.180/7f5f6861jw1e8qgp5bmzyj2050050aa8.jpg" //消息来源用户头像
             ,id: data[i]['question_id']//消息的来源ID(如果是私聊,则是用户id,如果是群聊,则是群组id)
             ,type: "friend" //聊天窗口来源类型,从发送消息传递的to里面获取
             ,content: data[i]['feedback']//消息内容
             ,cid: 0 //消息id,可不传。除非你要对消息进行一些操作(如撤回)
             ,mine: false //是否我发送的消息,如果为true,则会显示在右方
             ,fromid: data[i]['user_id'] //消息的发送者id(比如群组中的某个消息发送者),可用于自动解决浏览器多窗口时的一些问题
             ,timestamp: data[i]['zhuan_time'] * 1000 //服务端时间戳毫秒数。注意:如果你返回的是标准的 unix 时间戳,记得要 *1000
            });
           }
     }
  }
});
登入後複製

最後的傳送訊息什麼的,文件上面都有,這裡就不多說來,最後附一個全部程式碼
JS程式碼:

<script>
function im(question_id)
 {
   layui.use([&#39;layim&#39;,&#39;jquery&#39;], function(){
  var layim = layui.layim
  ,$ = layui.jquery;
   //基础配置
   layim.config({
    init: {
        url:"{:url(&#39;meet/get_user_chat&#39;)}"
        ,data:{question_id:question_id}
       }
       ,voice:false
       ,brief:false//是否简约模式,简约模式没有关闭按钮
       });
       // 清空所有本地缓存消息
       localStorage.clear();
       // 先打开窗口
       layim.chat({
       name: &#39;专家答疑&#39;
       ,type: &#39;friend&#39;
       ,avatar: &#39;//tva3.sinaimg.cn/crop.0.0.180.180.180/7f5f6861jw1e8qgp5bmzyj2050050aa8.jpg&#39;
       ,id: question_id
       });
       // 获取历史消息
       $.ajax({
       url:"{:url(&#39;meet/get_init_msg&#39;)}",
       type:"post",
       data:{question_id:question_id},
       dataType:"json",
       success:function (data) {
       if(data.length > 0){
       for (var i in data){
       layim.getMessage({
       username: "专家答疑" //消息来源用户名
       ,avatar: "http://tp1.sinaimg.cn/1571889140/180/40030060651/1" //消息来源用户头像
       ,id: data[i][&#39;question_id&#39;]//消息的来源ID(如果是私聊,则是用户id,如果是群聊,则是群组id)
       ,type: "friend" //聊天窗口来源类型,从发送消息传递的to里面获取
       ,content: data[i][&#39;content&#39;] //消息内容
       ,cid: 0 //消息id,可不传。除非你要对消息进行一些操作(如撤回)
       ,mine: true //是否我发送的消息,如果为true,则会显示在右方
       ,fromid: data[i][&#39;user_id&#39;] //消息的发送者id(比如群组中的某个消息发送者),可用于自动解决浏览器多窗口时的一些问题
       ,timestamp: data[i][&#39;addtime&#39;] * 1000 //服务端时间戳毫秒数。注意:如果你返回的是标准的 unix 时间戳,记得要 *1000
       });
  layim.getMessage({
       username: "专家答疑" //消息来源用户名
       ,avatar: "//tva3.sinaimg.cn/crop.0.0.180.180.180/7f5f6861jw1e8qgp5bmzyj2050050aa8.jpg" //消息来源用户头像
       ,id: data[i][&#39;question_id&#39;]//消息的来源ID(如果是私聊,则是用户id,如果是群聊,则是群组id)
       ,type: "friend" //聊天窗口来源类型,从发送消息传递的to里面获取
       ,content: data[i][&#39;feedback&#39;]//消息内容
       ,cid: 0 //消息id,可不传。除非你要对消息进行一些操作(如撤回)
       ,mine: false //是否我发送的消息,如果为true,则会显示在右方
       ,fromid: data[i][&#39;user_id&#39;] //消息的发送者id(比如群组中的某个消息发送者),可用于自动解决浏览器多窗口时的一些问题
       ,timestamp: data[i][&#39;zhuan_time&#39;] * 1000 //服务端时间戳毫秒数。注意:如果你返回的是标准的 unix 时间戳,记得要 *1000
       });
     }
  }
 }
});
// 监听发送消息
layim.on(&#39;sendMessage&#39;, function(res){
var mine = res.mine.content; //包含我发送的消息及我的信息
});
});
}
</script>
登入後複製

CSS程式碼:

<style>
        .layui-layim{
            display: none;
        }
    </style>
登入後複製

最後附上一張成品圖:

如何利用layim實現歷史記錄的初始化(附程式碼)

##相關推薦:


以上是如何利用layim實現歷史記錄的初始化(附程式碼)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板