搜尋
首頁後端開發GolangGo語言實作之基於websocket瀏覽器通知功能

Go語言實作之基於websocket瀏覽器通知功能

當我們使用了websocket技術實現了實時的推送訪客來到訊息,但是我們只能隨時看著頁面不離開才能知道有訪客來到

#現在增加瀏覽器的通知訊息,就可以只要打開著介面,不用一直盯著,幹別的事去就可以了,有新消息會從右下角彈出來

測試地址如下,當有訪客點擊諮詢按鈕時,客服後台會彈出提示:

https://gofly.sopans.com/index

首先要明確一點,現在的通知只能在https的環境下使用, 非https , 不能使用瀏覽器通知,Notification.permission返回的是禁止

  notify(title, options, callback) {
          // 先检查浏览器是否支持
          if (!window.Notification) {
            return;
          }
          var notification;
          // 检查用户曾经是否同意接受通知
          if (Notification.permission === 'granted') {
            notification = new Notification(title, options); // 显示通知

          } else {
            var promise = Notification.requestPermission();
          }

          if (notification && callback) {
            notification.onclick = function(event) {
              callback(notification, event);
            }
          }
       },
notify("标题", {
            body: "内容",
            icon: "头像"
          }, function(notification) {

            notification.close();

});

websocket部分就是監聽onmessage方法,根據返回的json訊息字段進行區分判斷,這裡是需要自己來定義,也可以參考上面地址的源代碼

#相關學習推薦:Go語言教學

以上是Go語言實作之基於websocket瀏覽器通知功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:jb51。如有侵權,請聯絡admin@php.cn刪除
陣列和切片的GO有什麼區別?陣列和切片的GO有什麼區別?Apr 28, 2025 pm 05:13 PM

本文討論了GO中的數組和切片之間的差異,重點是尺寸,內存分配,功能傳遞和用法方案。陣列是固定尺寸的,分配的堆棧,而切片是動態的,通常是堆積的,並且更靈活。

您如何在Go中創建切片?您如何在Go中創建切片?Apr 28, 2025 pm 05:12 PM

本文討論了在GO中創建和初始化切片,包括使用文字,製造功能以及切片現有數組或切片。它還涵蓋了切片語法並確定切片長度和容量。

您如何在Go中創建一個數組?您如何在Go中創建一個數組?Apr 28, 2025 pm 05:11 PM

本文說明瞭如何在GO中創建和初始化數組,討論數組和切片之間的差異,並解決了數組的最大尺寸限制。數組與切片:固定與動態,值與參考類型。

在GO中創建結構的語法是什麼?在GO中創建結構的語法是什麼?Apr 28, 2025 pm 05:10 PM

文章討論了GO中結構的語法和初始化,包括字段命名規則和結構嵌入。主要問題:如何有效地在GO編程中使用結構。 (字符:159)

您如何在GO中創建指針?您如何在GO中創建指針?Apr 28, 2025 pm 05:09 PM

本文在GO中解釋了創建和使用指針,討論了諸如有效的內存使用和安全管理實踐之類的好處。主要問題:安全指針使用。

使用GO有什麼好處?使用GO有什麼好處?Apr 28, 2025 pm 05:08 PM

本文討論了在軟件開發中使用GO(Golang)的好處,重點介紹其並發支持,快速彙編,簡單性和可擴展性優勢。受益的主要行業包括技術,金融和遊戲。

if語句中的語法是什麼?if語句中的語法是什麼?Apr 28, 2025 pm 05:07 PM

本文討論了go中if語句的語法和用法,包括if塊中的可變初始化和要避免的常見錯誤。它提供了構建if語句的最佳實踐。

您如何在Go中創建循環?您如何在Go中創建循環?Apr 28, 2025 pm 05:06 PM

文章討論了使用“ For”,“循環類型”,“優化技術”以及避免常見錯誤的創建循環。主要重點是GO中的有效循環使用。 [159個字符]

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器