登录
首页 >  Golang >  Go问答

Pusher 每次提交消息都会触发两次消息发送

来源:stackoverflow

时间:2024-03-23 13:27:32 268浏览 收藏

使用 Pusher 框架构建的聊天应用程序出现了一个问题,每次用户提交消息时都会触发两次消息发送。尽管代码中没有重复调用任何函数,但问题仍然存在。应用程序使用 React 和 Golang 开发,已排除函数重复调用的可能性。问题根源尚未找到,但怀疑可能是由于 React 严格模式导致的页面渲染两次,从而导致 useEffect 函数运行两次。

问题内容

推送者在提交时发送消息两次。我没有看到任何函数被重复或调用两次,但这仍然发生

我正在使用react v18.1.0 我正在使用 golang 1.18

import react, { usestate, useeffect } from "react";
import pusher from "pusher-js";

function app() {
  const [username, setusername] = usestate('username');
  const [messages, setmessages] = usestate([]);
  const [message, setmessage] = usestate('');
  let allmessages = [];

  useeffect(() => {
      pusher.logtoconsole = true;

      const pusher = new pusher('-', {
          cluster: '-'
      });

      const channel = pusher.subscribe('chat');
      channel.bind('message', function (data) {
          allmessages.push(data);
          setmessages(allmessages);
      });
  }, []);

  const submit = async e => {
      e.preventdefault();

      await fetch('http://localhost:8000/api/messages', {
          method: 'post',
          headers: {'content-type': 'application/json'},
          body: json.stringify({
              username,
              message
          })
      });

      setmessage('');
  }

  return (
      
setusername(e.target.value)}/>
{messages.map(message => { return (
{message.username}
{message.message}
) })}
submit(e)}> setmessage(e.target.value)} />
); } export default app;

这是我在 golang 中的后端代码

package main

import (
    "github.com/gofiber/fiber/v2"
    "github.com/gofiber/fiber/v2/middleware/cors"
    "github.com/pusher/pusher-http-go"
)

func main() {
    app := fiber.New()

    app.Use(cors.New())

    pusherClient := pusher.Client{
        AppID:   "1421095",
        Key:     "-",
        Secret:  "-",
        Cluster: "ap2",
        Secure:  true,
    }

    app.Post("/api/messages", func(c *fiber.Ctx) error {
        var data map[string]string

        if err := c.BodyParser(&data); err != nil {
            return err
        }

        pusherClient.Trigger("chat", "message", data)

        return c.JSON([]string{})

    })

    app.Listen(":8000")
}

我在网上搜索了很多,但我确实能找到解决方案。 以上是我为创建应用程序编写的所有代码


正确答案


好的,我明白了。我将 App.js 封装在 index.js 中的 React Strict 模式中。它导致我的页面渲染两次,useEffect 函数运行了两次。因此,如果有人遇到此问题,请确保您没有使用 React 严格模式

终于介绍完啦!小伙伴们,这篇关于《Pusher 每次提交消息都会触发两次消息发送》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>