迁移机器人框架 3-4:document.getElementsByClassName("wc-header") 不再工作

如何解决迁移机器人框架 3-4:document.getElementsByClassName("wc-header") 不再工作

我将代码从 webchat 3 更改为 webchat 4,还更改了样式选项等等。一切正常……只是网络聊天渲染产生了问题。 这是我的代码:

(async function() {
            const res = await fetch('https://directline.botframework.com/v3/directline/tokens/generate',{ 
            headers: {
              Authorization: `Bearer [MYBEARER]`,},method: 'POST'
          });
          const { token } = await res.json();
         

            const store = window.WebChat.createStore({},({ dispatch }) => next => action => {
                //console.log(action);
                if (action.type === 'DIRECT_LINE/CONNECT_FULFILLED') {
                    dispatch({
                        type: 'WEB_CHAT/SEND_EVENT',payload: {
                            name: 'webchat/join',value: { language: window.navigator.language }
                        }
                    });
                }

                return next(action);
            });
            const styleOptions = {
                botAvatarInitials: 'EY',userAvatarInitials: 'YOU'
            };
            const {
                    createCognitiveServicesSpeechServicesPonyfillFactory,createDirectLine,renderWebChat
                  } = window.WebChat;

            var div = document.createElement("div");
            document.getElementsByTagName('body')[0].appendChild(div);
            div.outerHTML = "<div id='botDiv' style='width: 400px; height: 0px; margin:10px; position: fixed; bottom: 0; right:0; z-index: 1000; background-color:#252525; border:1px solid #252525;'><div  id='botTitleBar' style='height: 40px; width: 400px; position:fixed; cursor: pointer; background-color:#FFE600;'></div></div>";
            
            window.WebChat.renderWebChat({
                directLine: window.WebChat.createDirectLine({ token }),webSpeechPonyfillFactory: window.WebChat.createBrowserWebSpeechPonyfillFactory(),store,userID: `You`,username: 'Web Chat User',locale: 'en-US',language: 'en-US',styleOptions
            },document.getElementById('botDiv'));
            document.querySelector('#botDiv > *').focus();
            

            
            document.querySelector('body').addEventListener('click',function (e) {
                e.target.matches = e.target.matches || e.target.msMatchesSelector;
                if (e.target.matches('#chatbotheader')) {
                    var botDiv = document.querySelector('#botDiv');

                    botDiv.style.height = "0px";

                    document.getElementById("mychat").style.display = "block";
                };
            });

            document.getElementById("mychat").addEventListener("click",function (e) {

                document.getElementById("botDiv").style.height = '500px';

                e.target.style.display = "none";
            })
        }()).catch(err => console.error(err));;

我的标题中还有所有 js 和 css 链接:

<link href="https://cdn.botframework.com/botframework-webchat/latest/botchat.css" rel="stylesheet" />
    <link rel="stylesheet" href="~/css/botchatey.css">
    <script src="https://cdn.botframework.com/botframework-webchat/latest/botchat.js"></script>
    <script crossorigin="anonymous" src="https://cdn.botframework.com/botframework-webchat/latest/webchat.js"></script>

问题出在: 当我删除“window.WebChat.renderWebChat”功能时,整个布局完美运行。我可以最大化和最小化我在 div-outerHTML 中创建的聊天窗口。

当我添加 renderWebChat 函数时,id 为“botTitleBar”的封装 DIV 似乎被吃掉了,并且没有显示出来。如果我在正在运行的解决方案中按 F12,则在运行的代码中看不到此 DIV。 我现在花了几个小时在这上面。 非常欢迎任何帮助!请!

解决方法

我自己解决了这个问题。花了我一些时间,但我认为对其他人来说很有趣,您是否也可以从网络聊天 3 更改为网络聊天 4。 我的网页端有一个图标,我想在网站打开时显示该图标。当我单击该图标时,网络聊天窗口将打开。当我单击网络聊天窗口的标题时,窗口会折叠并再次显示图标。 这是我需要的代码部分。 样式部分:

<style>
    html,body {
        height: 100%;
        width: 100%;
    }

    body {
        margin: 0;
    }

    #botDiv {
        width: 400px;
        height: 0px;
        margin: 10px;
        position: fixed;
        bottom: 0;
        right: 0;
        z-index: 1000;
        border: 1px solid #252525;
        display: none;
    }

    #botDiv>* {
        height: 100%;
        width: 100%;
    }

    #webchat>* {
        height: 100%;
        width: 100%;
    }
    
    #botTitleBar {
        cursor: pointer;
        background-color: #252525;
        height: 20px;
        width: auto;
        color: #252525;
    }

    #ContainerDiv {
      margin: auto;
      position: sticky;
      left: 0;
      bottom: 0;
      width: 100%;
    } 
</style>

图标的 div 和放置在页脚中的聊天窗口:

<div id="botDiv">
        <div id="botTitleBar">Click here to close chat window!</div>
        <div id="webchat"></div>
</div>
<div class="ContainerDiv" id="ContainerDiv">
        <img id="chaticon" src="@Url.Content("/images/chat.png")"  style="float: right;" role="main"/>
</div>

最后是 javascript 函数:

(async function() {
        
        const res = await fetch('https://directline.botframework.com/v3/directline/tokens/generate',{ 
            headers: {
              Authorization: `Bearer <YOUR DIRECTLINE SECRET HERE>`,},method: 'POST'
        });
        const { token } = await res.json();


        const store = window.WebChat.createStore({},({ dispatch }) => next => action => {
            //console.log(action);
            if (action.type === 'DIRECT_LINE/CONNECT_FULFILLED') {
                dispatch({
                    type: 'WEB_CHAT/SEND_EVENT',payload: {
                        name: 'webchat/join',value: { language: window.navigator.language }
                    }
                });
            }

            return next(action);
        });
        const styleOptions = {
            botAvatarInitials: 'EY',userAvatarInitials: 'YOU',hideUploadButton: true,backgroundColor: '#252525',userAvatarBackgroundColor: '#FFE600',botAvatarBackgroundColor: 'FFE600',sendBoxBackground: 'Black',sendBoxTextColor: 'White'

        };
        const {
                createCognitiveServicesSpeechServicesPonyfillFactory,createDirectLine,renderWebChat
              } = window.WebChat;

       

        window.WebChat.renderWebChat({
            directLine: window.WebChat.createDirectLine({ token }),webSpeechPonyfillFactory: window.WebChat.createBrowserWebSpeechPonyfillFactory(),store,userID: `You`,username: 'Web Chat User',locale: 'en-US',language: 'en-US',styleOptions
        },document.querySelector("#botDiv #webchat")
        );

        document.querySelector('#webchat > *').focus();
        
        document.querySelector( 'body' ).addEventListener( 'click',function (e) {
            const botDiv = document.getElementById("botDiv");
            const webchat = document.getElementById("webchat" );
            const chaticon = document.getElementById("chaticon" );
            const botTitleBar = document.getElementById("botTitleBar");
            e.target.matches = e.target.matches || e.target.msMatchesSelector;
            const parent = e.srcElement.parentElement;
            if (parent.matches( '#botDiv' ) && e.target.matches( '#botTitleBar' ) ) {
                botDiv.style.height = '0px';
                botDiv.style.display = "none";
                chaticon.style.display = "initial";
            }
            else if ( e.target.matches( '#chaticon') ) {
                document.getElementById( "botDiv" ).style.height = '500px';
                botDiv.style.display = "block";
                botDiv.appendChild( webchat );
                botTitleBar.style.backgroundColor = "#FFE600";
                chaticon.style.display = "none";
            };
        });

       
    }()).catch(err => console.error(err));

我知道直达线的秘密不应该直接在代码中,但由于我的页面只是一个演示页面,所以我让它变得容易。 由于我一直在寻找解决方案,我认为如果您遇到同样的问题,这可能会对您有所帮助。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)&gt; insert overwrite table dwd_trade_cart_add_inc &gt; select data.id, &gt; data.user_id, &gt; data.course_id, &gt; date_format(
错误1 hive (edu)&gt; insert into huanhuan values(1,&#39;haoge&#39;); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive&gt; show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 &lt;configuration&gt; &lt;property&gt; &lt;name&gt;yarn.nodemanager.res