微信小程序自动回复机器人(模拟云信案例)

article/2025/8/22 19:22:12

1.场景:

输入关键词,对内容库进行检索,得到搜索结果,反馈给用户。其实也不算是机器人,也类似于搜索的样子,只不过以聊天界面的形式展现出来,当然了,在完成这个流程的过程中,也会出现一些问题,思路记录,仅供参考。

2.思路:

2.1 毋庸置疑,首先搭建前端界面(这块没什么可说的,对方和自己的样式最好大多数一样,通过一个‘me’和‘you’来进行区分,比较好);

2.2 逻辑处理部分(数据缓存处理):

有些可能需要做消息的缓存处理,利用‘键名’和‘键值’保存即可(但当然了,这不是惠话)。如果业务比较简单,一个城市,一个机器人,不要判断今天是今天(有些场景可能会涉及默认消息,比如默认消息,今天只发送一次,然后等明天再发送,怎么判断今天是今天)。所以如下:

2.2.1这里最好以城市加一个后缀或者前缀为键值,对发送过的消息进行做缓存处理。把城市做键值,缓存的消息体以json格式(外层数组方便遍历,数组内层每项以对象形式,对象中每一项通过键值对的方式,添加自己所需要的字段内容即可)。

2.2.2 判断今天是否发过默认消息(判断今天是今天),通过时间来区分,时间是唯一的。每发送一条消息时,获取时间(只取年月日),每次发送时从缓存中取时间,若缓存中无时间或缓存中的时间和当前时间不一致则把当前时间存入缓存并发送默认消息,若缓存时间和当前时间一致则不用更新缓存时间。每次发送消息都需要更新本地缓存记录。

2.2.3 缓存的消息一般需要做条数限制(因为小程序对缓存大小有上限),每发一条消息取出缓存中的消息把这条消息加入到取出的数组中,同时判断这个取出的数组长度是否大于最大条数限制,如果超过了就把取出的数组的第一删掉,如果没超过则不用管,然后再把取出的数组存入缓存中即可。

3.代码

3.1wxml

<view class='chating-wrapper'><!--消息展示--><view class='record-wrapper'><view wx:if="{{current_list.length}}"><block wx:for="{{current_list}}" wx:for-item='list' wx:for-index='listidx'><!-- 收 --><view class="record-chatting-item {{list.kind=='you'?'other':''}}" wx:if="{{list.kind=='you'}}"><view class="record-chatting-item-img"></view><view class="record-chatting-item-text qst"><view class='qst-ul'><view class="qst-li">{{list.list_ul}}</view></view></view></view><!-- 发 --><view class="record-chatting-item {{list.kind=='me'?'self':''}}"  wx:if="{{list.kind=='me'}}"><view class="record-chatting-item-text qst"><view class='qst-ul'><view class="qst-li">{{list.list_ul}}</view></view></view><view class="record-chatting-item-img"></view></view></block></view></view>
</view>
<!--输入框-->
<view class="chatinput-wrapper {{input_flag?'mb16':''}}"><view class="chatinput-content flex alignC flexSb"><view class="chatinput-img"></view><view class='chatinput-inputOut'><input class='chatinput-input' bindinput='inputChange' bindconfirm='inputSend' placeholder='请输入关键词"' confirm-type='send' value='{{inputValue}}' bindfocus='inputFocus' bindblur='inputBlue'></input></view><view class='chatinput-sendOut'><view class='chatinput-send' catchtap='inputSend'>发送</view></view></view>
</view>

3.2wxss

page {height: 100%;background-color: #f3f4f6;
}.chating-wrapper {width: 100%;min-height: 100%;position: relative;box-sizing: border-box;background: #f6f6f6;
}.record-chatting-item {width: 100%;padding: 28rpx 23rpx 0;box-sizing: border-box;
}.record-chatting-item-img, .open-data-userAvatarUrl {width: 70rpx;height: 70rpx;border-radius: 100%;display: block;overflow: hidden;
}.other {display: flex;flex-direction: row;justify-content: flex-start;color: #222;
}.other .record-chatting-item-text {margin-left: 20rpx;margin-right: 0;
}.self {display: flex;flex-direction: row;justify-content: flex-end;color: #fff;
}.record-chatting-item-text {width: 455rpx;border-radius: 8rpx;background-color: #fff;padding: 26rpx;box-sizing: border-box;word-wrap: break-word;overflow: hidden;font-size: 26rpx;line-height: 42rpx;box-shadow: 0 0 8rpx #dedede;
}.qst-li {font-size: 26rpx;line-height: 1.1;padding: 16rpx 6rpx;border-bottom: 1rpx solid #d9d9d9;
}.qst-li:last-child {border: none;
}/*底部输入框*/.chatinput-wrapper {width: 100%;background-color: #fff;border-bottom: 1rpx solid gray;position: fixed;bottom: 0;left: 0;height: 92rpx;
}.chatinput-img {width: 59rpx;height: 59rpx;border-radius: 100%;
}.other .record-chatting-item-img,.chatinput-img,.self .record-chatting-item-img {background-image: url();background-repeat: no-repeat;background-position: center;background-size: 100%;
}.chatinput-content {width: 100%;height: 92rpx;box-sizing: border-box;padding: 0 24rpx;
}.chatinput-inputOut {width: 490rpx;height: 60rpx;position: relative;box-sizing: border-box;padding-left: 20rpx;padding-right: 20rpx;background: #f0f0f0;border-radius: 60rpx;
}.chatinput-inputmask {width: 490rpx;height: 60rpx;position: absolute;left: 0;top: 0;border-radius: 60rpx;z-index: 2;
}.chatinput-input {width: 100%;height: 60rpx;border-radius: 60rpx;border: none;display: inline-block;vertical-align: top;font-size: 28rpx;color: #212121;background: #f0f0f0;
}.chatinput-sendOut {width: 90rpx;height: 60rpx;position: relative;
}.chatinput-sendmask {width: 90rpx;height: 60rpx;position: absolute;left: 0;top: 0;border-radius: 60rpx;color: #fff;background: #d0d0d0;line-height: 60rpx;font-size: 26rpx;
}.chatinput-send {width: 90rpx;height: 60rpx;line-height: 60rpx;text-align: center;border-radius: 60rpx;color: #fff;font-size: 26rpx;background-color: orange;
}.flex {display: flex;
}.alignC {align-items: center;
}.flexSb {justify-content: space-between;
}.self .record-chatting-item-text {background: #38adfa;margin-right: 20rpx;margin-left: 0;
}.mb16{margin-bottom: 16rpx;
}.record-wrapper{padding-bottom: 122rpx;
}

3.3 js

var app = getApp();
Page({/*** 页面的初始数据*/data: {// 输入框的值inputValue: '',// 当前聊天数据的列表的indexcurrent_index: 0,// 数据列表 current_list: [],// 缓存最多存的消息条数max_length: 5,// 是否聚焦input_flag: false,// 城市mycity: 'bj'},/*** 生命周期函数--监听页面显示*/onShow: function() {var that = this;// 首先从缓存中拿缓存的值,若有,则优先渲染that.getRecord();},// 获取缓存记录getRecord() {var that = this;var current_list = that.data.current_list;var key_time = 'my' + that.data.mycity + 'time';var key_list = 'my' + that.data.mycity + 'list';// 初始化var myRecord_time = (wx.getStorageSync(key_time) == undefined || wx.getStorageSync(key_time) == '') ? '' : wx.getStorageSync(key_time);var myRecord_list = (wx.getStorageSync(key_list) == undefined || wx.getStorageSync(key_list) == '') ? '' : wx.getStorageSync(key_list);if (myRecord_time && myRecord_list.length) {console.log(myRecord_list)that.setData({current_list: myRecord_list,current_index: myRecord_list.length}, function() {that.scrollToBottom();});}},// 创建缓存记录setRecord(par_kind, par_list) {var that = this;var current_list = that.data.current_list;var key_time = 'my' + that.data.mycity + 'time';var key_list = 'my' + that.data.mycity + 'list';// 初始化var myRecord_time = (wx.getStorageSync(key_time) == undefined || wx.getStorageSync(key_time) == '') ? '' : wx.getStorageSync(key_time);var myRecord_list = (wx.getStorageSync(key_list) == undefined || wx.getStorageSync(key_list) == '') ? [] : wx.getStorageSync(key_list);if (!myRecord_time) {wx.setStorage({key: key_time,data: myRecord_time,});}if (!myRecord_list) {wx.setStorage({key: key_list,data: [],});}myRecord_time = wx.getStorageSync(key_time);// 如果缓存中没有时间 或者 和今天的截止时间不一致时,须把今天的截止日期赋给它,同时发送默认消息,同时把截止日赋值给缓存,同时发送默认消息,同时把默认消息开关设置为trueif (myRecord_time == '') {myRecord_time = get_endtime();// 用最新的覆盖wx.setStorage({key: key_time,data: myRecord_time,});}// 列表(将获取到的数据从头部添加,相当于最新的)var listdata = {'kind': par_kind,'list_ul': par_list};if (par_kind && par_list) {myRecord_list.push(listdata)}// 如果超过最大长度,需要截断if (myRecord_list.length > that.data.max_length) {myRecord_list.splice(0, 1)}wx.setStorage({key: key_list,data: myRecord_list,});},// 改变消息列表change_list(par_kind, par_list) {var that = this;var current_index = that.data.current_index;var data_key = "current_list[" + that.data.current_index + "]";var listdata = {'kind': par_kind,'list_ul': par_list};that.setData({current_index: current_index + 1,[data_key]: listdata,});if (par_kind == 'me') {that.setData({inputValue: ''});}},/*** 文本框输入事件*/inputChange(e) {var that = this;that.setData({inputValue: e.detail.value,});},// 发送消息inputSend() {var that = this;var inputValue = that.data.inputValue;if (inputValue) {var param = {city: that.data.mycity,keyword: inputValue,}// 创建记录 往上滚动that.scroll_record_list('me', inputValue);// 搜索结果var num_arr = ["你好哇", "我是元气满满的萌妹子", "你问这个干什么", "尼古拉·阿列克谢耶维奇·奥斯特洛夫斯基", "我在你的内心深处"];var num = Math.floor(Math.random() * 5);console.log(num)if (num != 6) {that.scroll_record_list('you', num_arr[num]);} else {that.scroll_record_list('you', '没有搜索到"' + inputValue + '"相关内容');}}},// 聚焦,失焦inputFocus(e) {var that = this;that.setData({input_flag: true});},inputBlue() {var that = this;that.setData({input_flag: false});},// 创建记录,同时页面往上滚动scroll_record_list(par_kind, par_list) {var that = this;// 改变消息列表that.change_list(par_kind, par_list);// 创建记录that.setRecord(par_kind, par_list);// 往上滚动that.scrollToBottom();},/*** 滚动页面到底部*/scrollToBottom() {wx.pageScrollTo({scrollTop: 999999,duration: 100});},
})// 获取当日23:59:59时间
function get_endtime() {var time_end = new Date(new Date(new Date().toLocaleDateString()).getTime() + 24 * 60 * 60 * 1000 - 1);var time_format = format_date(time_end)return time_format;
}// 获取当前时间的  年月日时分秒  的时间格式化 20191220100246
function format_date(now) {var year = now.getFullYear(); //年var month = now.getMonth() + 1; //月var day = now.getDate(); //日var hh = now.getHours(); //时var mm = now.getMinutes(); //分var ss = now.getSeconds(); //秒var clock = year + "";if (month < 10) {clock += "0";}clock += month + "";if (day < 10) {clock += "0";}clock += day + "";if (hh < 10) {clock += "0";}clock += hh + "";if (mm < 10) {clock += '0'}clock += mm;if (ss < 10) {clock += '0'}clock += ss;return clock;
}

4.效果

 

5.说明

5.1 最好封装一个滚动函数,每次发送消息或者每次一进入页面从缓存中读取数据并赋值给当前渲染的数组以后页面就会渲染更新,此时也需要将页面滚动到最底部才比较合理,封装滚动函数后在这两个地方可直接调用就好了;

5.2 键盘需要做一个底部悬浮,但你会发现 position:fixed;bottom:0 当键盘弹起后,键盘会贴着input的底框框,此时需要做一个聚焦和失焦的处理,聚焦(也就是键盘弹起后给以margin-bottom),失焦的时候再把底部的margin-bottom去掉即可;

5.3 最开始我还想过通过index做键值的方式对消息缓存更新,后来感觉会有问题(index不靠谱,会出现重复,如果我发了二十条,有一个index二十,明天只取十条,我明天再发到第二十条的index就和之前的index值一样了)(这条可忽略);

5.4 对于键盘弹起的问题,如果页面消息比较少会存在键盘把消息顶上去的情况,其实对于顶的情况,微信和QQ都是默认让顶的(这样每次都能保证在输入框聚焦的时候,能看到最后一条消息,这也时合理的)。如果你有特别的需要,你们公司产品不让顶上去,可以参考(思路:键盘固定,聚焦也固定,当消息比较多的时候,会挡住最后几条)。其实对于需要顶或者不顶各有优劣吧,根据自己需求取舍。


http://chatgpt.dhexx.cn/article/yXjeyLSi.shtml

相关文章

微信话术自动回复机器人软件

购买地址 &#xff1a; https://item.taobao.com/item.htm?ftt&id644635811302自动通过好友验证以及计数 1.设置通过好友验证时长&#xff0c;一般为2-3秒 2.设置启用新好友信息之后&#xff0c;通过的新好友自动发送保存好的文字/表情 3.好友计数指的是已经添加通过验证…

微信机器人自动回复(python实现)

微信机器人自动回复&#xff08;python实现&#xff09; 准备工作&#xff1a; 自动回复利用了图灵机器人的智能问答&#xff0c;需要在图灵网创建一个机器人&#xff0c;这时会得到一个apike 1、安装python以及python编译器 2、复制粘贴代码 import itchat import requests…

用Python做个微信自动回复机器人

微信已经成为我们生活不可或缺的一部分&#xff0c;每天有380亿条消息从微信上发出&#xff0c;其中6亿条是语音消息&#xff0c;有350万个活跃的公众账号&#xff0c;并存在着8亿活跃粉丝。微信是一个庞大的生态群体。 今天我们来玩转一下微信&#xff0c;微信有关的第三方框…

微信自动回复的智能聊天机器人怎么做?

wx微信简单话术群消息同步机器人,简单明了效率高。 工具 先安装微信特定版本3.0.0.57,后打开WeiChatTool.exe运行使用/操作 操作主界面如下: 自动通过好友验证以及计数 1.设置通过好友验证时长,一般为2-3秒 2.设置启用新好友信息之后,通过的新好友自动发送保存好的文字/…

如何用 30 行代码实现微信自动回复机器人?

作者 | Ahab 责编 | 胡巍巍 写在前面 很多朋友对itchat非常感兴趣&#xff0c;近日又学到了itchat另一种有趣的玩法——微信自动回复机器人。 程序很简单仅仅三十行代码左右&#xff0c;实现了机器人自动与你的微信好友聊天&#xff0c;下面是我的机器人小笼包跟自己微信好友聊…

手把手教你实现一个微信自动回复机器人

RebateBot 返利机器人 微信聊天机器人代码 项目地址 项目描述 关键词: 返利 微信 阿里妈妈 机器人 跨平台 返利机器人&#xff0c;基于微信建立机器人通道与用户通过聊天快速生成返利链接 利用闲置微信和极小的电脑性能开启24小时无人轮值返利机器人 购物只需要发送链接给…

超简单Python实现微信机器人自动回复

下面这个小文章适合初学Python的童鞋哦~~~ 一个很好用的微信库&#xff1a;itchat 拿使用图灵机器人设置自动回复&#xff0c;让机器人跟微信好友傻傻的聊天&#xff0c;机器人比小编还会聊天&#xff0c;无论是对美眉还是汉纸&#xff0c;上来就是爱&#xff01;爱&#xff…

怎么做一个微信自动回复的智能聊天机器人?

微信自动回复机器人的操作很简单&#xff0c;只需要完成30行代码&#xff0c;就可以让机器人实现查天气、查星座运势、智能回复、关键词回复等功能。 下面我们看个例子&#xff1a; 在程序设定时通过itchat获取微信信息&#xff0c;将微信消息传输到机器人的接口&#xff0…

微信自动回复机器人使用教程

第一步&#xff0c;打开软件&#xff0c;选择关键词回复一栏 第二步&#xff1a;单击鼠标右键选择添加一个词&#xff0c;设置好关键词&#xff0c;回复词&#xff0c;选择回复到哪个微信群即可。 第三步&#xff1a;测试一下效果 第四步&#xff1a;操作就是这么简单&#xff…

如何训练创建一个聊天自动回复的微信机器人(一)

如何创建一个聊天自动回复的微信机器人&#xff08;一&#xff09; 这里&#xff0c;本来打算用一个微信号来做机器人的&#xff0c;但是机器人有几个缺点 1、如果任意一个人想使用机器人的话&#xff0c;那么必须添加机器人为好友才能使用测试 2、基于微信识别异常微信号的自…

Python几十行代码轻松实现微信自动回复机器人

Python几十行代码轻松实现微信自动回复机器人 最近因为太无聊了就考虑能不能做一些好玩的东西出来&#xff0c;正好在CSDN的推荐上看到大佬做的微信自动回复机器人&#xff0c;觉得很有趣&#xff0c;因此想着自己也能动手做一个。在此就写下我的具体思路和实现过程吧。 首先&…

多核CPU算法

多核CPU环境下的进程调度算法有哪些&#xff0c;与单核CPU环境下的进程调度有何不同&#xff1f; 多核CPU调度算法 全局队列调度 操作系统维护一个全局的任务等待队列。当系统中有一个CPU核心空闲时&#xff0c;操作系统就从全局任务等待队列中选取就绪任务开始在此核心上执…

多CPU和多核CPU对应多进程和多线程调度

目录 cpu架构和工作原理多核cpu和多cpu 架构cpu的缓存进程和线程进程和线程在多核cpu&#xff0c;多cpu中的运行关系 cpu架构和工作原理 计算机有5大基本组成部分&#xff0c;运算器&#xff0c;控制器&#xff0c;存储器&#xff0c;输入和输出。运算器和控制器封装到一起&a…

单核CPU vs. 多核CPU

单核CPU vs. 多核CPU 单核CPU 起源&#xff1a; CPU的起源是1971年英特尔公司推出&#xff0c;由此正式宣告计算机的诞生&#xff0c;可以说是世界级的改变&#xff0c;并且严格准守冯诺依曼体系结构&#xff0c;在英特尔推出CPU之前的计算机所使用的处理器工作是非常麻烦的…

多核计算机是指有多个cpu,多核和多个CPU有什么区别?

多核和多个CPU有什么区别&#xff1f; 多核和多个CPU有什么区别&#xff1f;首先让我们了解以下两项: 什么是多核CPU&#xff1f;简单的理解是&#xff0c;我们将多个内核加载到一个程序包中&#xff0c;让用户了解这是一个处理器. 这样做的好处是&#xff0c;最初在单台计算机…

多核CPU、多CPU与多进程、多线程关系

文章目录 1 cpu架构和工作原理2 多核cpu和多cpu架构3 进程和线程4 多核、多CPU与多线程、多进程的对应关系5 总结 1 cpu架构和工作原理 计算机有5大基本组成部分&#xff0c;运算器&#xff0c;控制器&#xff0c;存储器&#xff0c;输入和输出。运算器和控制器封装到一起&…

多核与多处理器的区别

一、定义 多核&#xff1a;单块CPU上面能处理数据的芯片组的数量&#xff0c;比如&#xff0c;双核就是包括2个相对独立的CPU核心单元组&#xff0c;四核就包含4个相对独立的CPU核心单元组。 多处理器&#xff1a;主板上实际插入的cpu数量&#xff0c;一般有两个或者多个处理…

多核CPU和单核的区别~

昨天有同学问我多核cpu和单核的区别大不大&#xff0c;今天简单写一篇回复下吧。大家有其他问题也可以文末给我留言&#xff0c;我会尽量抽时间写文回复。 首先回顾下基本概念&#xff0c;cpu&#xff0c;就是中央处理器&#xff0c;包括运算器和控制器。cpu的主要功能就是“一…

多核处理器结构

文章目录 一、多核处理器的发展演化二、多核处理器的访存结构2.1 通用多核处理器的片上Cache结构2.2 存储一致性模型2.3 Cache一致性协议 三、多核处理器的互连结构3.1 片上总线3.2 交叉开关3.3 片上网络 四、多核处理器的同步机制4.1 原子操作4.2 锁的软件实现方法4.3 屏障软件…

关于 CPU 的多核和超线程技术

1. 关于 CPU 的多核和超线程技术 CPU 的物理个数由主板上的插槽数量决定&#xff0c;每个 CPU 可以有多核心&#xff0c;每核心可能会有多线程。 多核 CPU 的每核(每核都是一个小芯片)&#xff0c;在 OS 看来都是一个独立的 CPU。 对于超线程 CPU 来说&#xff0c;每核 CPU …