国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目錄
如何使用小程式Log 日誌系統(tǒng)" >如何使用小程式Log 日誌系統(tǒng)
首頁 微信小程式 小程式開發(fā) 聊聊小程式中的 Log 日誌系統(tǒng),看看怎麼搭建和使用

聊聊小程式中的 Log 日誌系統(tǒng),看看怎麼搭建和使用

Jan 21, 2022 am 10:26 AM
小程式

這篇文章帶大家聊聊小程式中的 Log 日誌系統(tǒng),介紹如何使用小程式 Log 日誌系統(tǒng),以及如何建立小程式 Log 日誌系統(tǒng),希望對大家有幫助!

聊聊小程式中的 Log 日誌系統(tǒng),看看怎麼搭建和使用

通常情況下,日誌系統(tǒng)是開發(fā)中重要的一環(huán)。

但基於種種原因,在前端開發(fā)中做日誌列印和上報系統(tǒng)卻不常見。
但在某些特定情況下,日誌系統(tǒng)往往有奇效。

例如一個聊天系統(tǒng)中遇到了以下問題:

  • 語音通話中,用戶聽不到聲音
  • 即時通訊中,部分場景用戶回饋,訊息發(fā)送不出去
  • 即時通訊中, A 回覆B 訊息時,偶爾對話方塊不顯示
  • 即時通訊中, A 給B 連續(xù)發(fā)送兩則訊息後, B 接收不到第二條的提示
  • 即時通訊中,發(fā)送語音訊息發(fā)送時,用戶以為語音已經(jīng)發(fā)送,但實際上錄音還在繼續(xù)。這時用戶以為是網(wǎng)路卡了,最後發(fā)現(xiàn)自己和其他人說話的聲音被錄製進去

但是以上幾種錯誤,在後臺介面中並沒有體現(xiàn)。再加上部分用戶手機型號的問題,導致問題很難被定位。
如果我們這裡有 log ,我們就能很快定位到出問題的程式碼。
如果不是程式碼問題,也更有底氣回覆使用者不是我們系統(tǒng)的問題。

如何使用小程式Log 日誌系統(tǒng)

小程式側(cè)提供了兩個小程式Log 日誌介面:

  • #LogManager ( 普通日誌 )
  • RealtimeLogManager ( 即時日誌 )
##官方並沒有介紹兩者的具體差異,只是強調(diào)了Realtime 的即時性質(zhì)。

在我看來他們的最大差異就是:

  • LogManager 可以讓使用者有種心安的感覺,因為LogManager 是用戶手動回饋的問題。
  • RealtimeLogManager 則對開發(fā)者更友好,可以在使用者不知情的情況下收集到問題信息,並在使用者無感的情況下對問題進行修復。

LogManager

小程式提供的

Log 日誌接口,透過wx.getLogManager( ) 取得實例。 注意:

    最多儲存5M的日誌內(nèi)容,超過5M後,舊的日誌內(nèi)容會被刪除。
  • 對於
  • 小程式 ,使用者可以透過使用?button?元件的?open-type="feedback"?來上傳列印的日誌。
  • 對於
  • 小遊戲 ,使用者可以透過使用?wx.createFeedbackButton?來建立上傳列印的日誌的按鈕。
  • 開發(fā)者可以透過小程式管理後臺左側(cè)選單
  • 回饋管理 頁面查看相關列印日誌。

建立 LogManager 實例

#你可以透過

wx.getLogManager() 取得日誌實例。 括號中可以傳參
{ level: 0 | 1 } 來決定是否寫入Page 的生命週期函數(shù), wx 命名空間下的函數(shù)紀錄.

    0:寫入
  • 1: 不寫入
  •  https://github.com/Kujiale-Mobile/Painter

使用LogManager 實例

const logger = wx.getLogManager({ level: 0 })
logger.log({str: 'hello world'}, 'basic log', 100, [1, 2, 3])
logger.info({str: 'hello world'}, 'info log', 100, [1, 2, 3])
logger.debug({str: 'hello world'}, 'debug log', 100, [1, 2, 3])
logger.warn({str: 'hello world'}, 'warn log', 100, [1, 2, 3])

使用者回饋上傳LogManager 記錄的日誌

#當日誌記錄後, 使用者可以在小程式的

profile 頁面,點選回饋與投訴 ,在點擊功能異常 進行日誌上傳。

開發(fā)者處理使用者回饋及與使用者溝通

#開發(fā)者可以在小程式後臺

管理 -> 使用者回饋 -> 功能異常 查看使用者回饋的資訊。 開發(fā)者可以在
功能 -> 客服 下綁定客服微信,綁定後可以在48小時 內(nèi)透過微信和回饋使用者溝通。

附註:溝通需要使用者回饋時勾選:允許開發(fā)者在 48 小時內(nèi)透過客服訊息聯(lián)絡我。

RealtimeLogManager

小程式提供的

即時Log 日誌接口,透過wx.getRealtimeLogManager () 取得實例。 注意:

  • wx.getRealtimeLogManager() 基礎庫 2.7.1 開始支持
  • 官方給出實時日志每條的容量上限是 5kb
  • 官方對每條日志的定義:在一個頁面 onShow -> onHide 之間,會聚合成一條日志上報
  • 開發(fā)者可從小程序管理后臺: 開發(fā) -> 運維中心 -> 實時日志 進入小程序端日志查詢頁面

為了定位問題方便,日志是按頁面劃分的,某一個頁面,在onShow到onHide(切換到其它頁面、右上角圓點退到后臺)之間打的日志,會聚合成一條日志上報,并且在小程序管理后臺上可以根據(jù)頁面路徑搜索出該條日志

創(chuàng)建 RealtimeLogManager 實例

你可以通過 wx.getRealtimeLogManager() 獲取實時日志實例。

const logger = wx.getRealtimeLogManager()

使用 RealtimeLogManager 實例

const logger = wx.getRealtimeLogManager()
logger.debug({str: 'hello world'}, 'debug log', 100, [1, 2, 3])
logger.info({str: 'hello world'}, 'info log', 100, [1, 2, 3])
logger.error({str: 'hello world'}, 'error log', 100, [1, 2, 3])
logger.warn({str: 'hello world'}, 'warn log', 100, [1, 2, 3])

查看實時日志

與普通日志不同的是,實時日志不再需要用戶反饋,可以直接通過以下方式查看實例。

  • 登錄小程序后臺

  • 通過路徑 開發(fā) -> 開發(fā)管理 -> 運維中心 -> 實時日志 查看實時日志

如何搭建小程序 Log 日志系統(tǒng)

上面我們知道了小程序的 Log 日志怎么使用,我們當然可以不進行封裝直接使用。
但是我們直接使用起來會感覺到十分的別扭,因為這不符合我們程序員單點調(diào)用的習慣。

那么接下來讓我們對這套 Log 系統(tǒng)進行初步的封裝以及全局的方法的日志注入。

后續(xù)我會在 github 開放源碼,并打包至 npm ,需要的開發(fā)者可自行 install 調(diào)用。

封裝小程序 Log 方法

封裝 Log 方法前,我們需要整理該方法需要考慮什么內(nèi)容:

  • 打印格式:統(tǒng)一打印格式有助于我們更快的定位問題
  • 版本號:方便我們清晰的知道當前用戶使用的小程序版本,避免出現(xiàn)舊版本問題在新代碼中找不到問題
  • 兼容性:我們需要考慮用戶小程序版本不足以支持 getLogManagergetRealtimeLogManager 的情況
  • 類型:我們需要兼容 debug 、 log 、 error 類型的 log日志

版本問題

我們需要一個常量用以定義版本號,以便于我們定位出問題的代碼版本。
如果遇到版本問題,我們可以更好的引導用戶

const VERSION = "1.0.0"
const logger = wx.getLogManager({ level: 0 })

logger.log(VERSION, info)

打印格式

我們可以通過 [version] file | content 的統(tǒng)一格式來更快的定位內(nèi)容。

const VERSION = "1.0.0"
const logger = wx.getLogManager({ level: 0 })

logger.log(`[${VERSION}] ${file} | `, ...args)

兼容性

我們需要考慮用戶小程序版本不足以支持 getLogManagergetRealtimeLogManager 的情況

const VERSION = "0.0.18";

const canIUseLogManage = wx.canIUse("getLogManager");
const logger = canIUseLogManage ? wx.getLogManager({ level: 0 }) : null;
const realtimeLogger = wx.getRealtimeLogManager ? wx.getRealtimeLogManager() : null;

export function RUN(file, ...args) {
  console.log(`[${VERSION}]`, file, " | ", ...args);
  if (canIUseLogManage) {
    logger.log(`[${VERSION}]`, file, " | ", ...args);
  }

  realtimeLogger && realtimeLogger.info(`[${VERSION}]`, file, " | ", ...args);
}

類型

我們需要兼容 debug 、 log 、 error 類型的 log日志

export function RUN(file, ...args) {
    ...
}

export function DEBUG(file, ...args) {
    ...
}

export function ERROR(file, ...args) {
    ...
}

export function getLogger(fileName) {
  return {
    DEBUG: function (...args) {
      DEBUG(fileName, ...args)
    },
    RUN: function (...args) {
      RUN(fileName, ...args)
    },
    ERROR: function (...args) {
      ERROR(fileName, ...args)
    }
  }
}

完整代碼

以上都做到了,就完成了一套 Log 系統(tǒng)的基本封裝。

const VERSION = "0.0.18";

const canIUseLogManage = wx.canIUse("getLogManager");
const logger = canIUseLogManage ? wx.getLogManager({ level: 0 }) : null;
const realtimeLogger = wx.getRealtimeLogManager ? wx.getRealtimeLogManager() : null;

export function DEBUG(file, ...args) {
  console.debug(`[${VERSION}] ${file}  | `, ...args);
  if (canIUseLogManage) {
    logger.debug(`[${VERSION}]`, file, " | ", ...args);
  }

  realtimeLogger && realtimeLogger.info(`[${VERSION}]`, file, " | ", ...args);
}

export function RUN(file, ...args) {
  console.log(`[${VERSION}]`, file, " | ", ...args);
  if (canIUseLogManage) {
    logger.log(`[${VERSION}]`, file, " | ", ...args);
  }

  realtimeLogger && realtimeLogger.info(`[${VERSION}]`, file, " | ", ...args);
}

export function ERROR(file, ...args) {
  console.error(`[${VERSION}]`, file, " | ", ...args);
  if (canIUseLogManage) {
    logger.error(`[${VERSION}]`, file, " | ", ...args);
  }

  realtimeLogger && realtimeLogger.error(`[${VERSION}]`, file, " | ", ...args);
}

export function getLogger(fileName) {
  return {
    DEBUG: function (...args) {
      DEBUG(fileName, ...args)
    },
    RUN: function (...args) {
      RUN(fileName, ...args)
    },
    ERROR: function (...args) {
      ERROR(fileName, ...args)
    }
  }
}

全局注入 Log

通過該章節(jié)的名稱,我們就可以知道全局注入。
全局注入的意思就是,不通過手動調(diào)用的形式,在方法寫完后自動注入 log ,你只需要在更細節(jié)的地方考慮打印 log 即可。

為什么要全局注入

雖然我們實現(xiàn)了全局 log 的封裝,但是很多情況下,一些新同學沒有好的打 log 的習慣,尤其是前端同學(我也一樣)。
所以我們需要做一個全局注入,以方便我們的代碼書寫,也避免掉手動打 log 會出現(xiàn)遺漏的問題。

如何進行全局注入

小程序提供了 behaviors 參數(shù),用以讓多個頁面擁有相同的數(shù)據(jù)字段和方法。

需要注意的是, page 級別的 behaviors 在 2.9.2 之后開始支持

我們可以通過封裝一個通用的 behaviors ,然后在需要 log 的頁面進行引入即可。

import * as Log from "./log-test";

export default Behavior({
  definitionFilter(defFields) {
    console.log(defFields);
    Object.keys(defFields.methods || {}).forEach(methodName => {
      const originMethod = defFields.methods[methodName];
      defFields.methods[methodName] = function (ev, ...args) {
        if (ev && ev.target && ev.currentTarget && ev.currentTarget.dataset) {
          Log.RUN(defFields.data.PAGE_NAME, `${methodName} invoke, event dataset = `, ev.currentTarget.dataset, "params = ", ...args);
        } else {
          Log.RUN(defFields.data.PAGE_NAME, `${methodName} invoke, params = `, ev, ...args);
        }
        originMethod.call(this, ev, ...args)
      }
    })
  }
})

總結

連著開發(fā)帶整理,林林總總的也有了 2000+ 字,耗費了三天的時間,整體感覺還是比較值得的,希望可以帶給大家一些幫助。

也希望大家更重視前端的 log 一點。這基于我自身的感覺,尤其是移動端用戶。
在很多時候由于 手機型號 、 弱網(wǎng)環(huán)境 等導致的問題。
在沒有 log 時,找不到問題的著力點,導致問題難以被及時解決。

后續(xù)我會在 github 開放源碼,并打包至 npm ,開發(fā)者后續(xù)可自行 install 調(diào)用。
后續(xù) 源碼地址npm安裝方法 將會在該頁面更新。
開放時間基于大家需求而定。

【相關學習推薦:小程序開發(fā)教程

以上是聊聊小程式中的 Log 日誌系統(tǒng),看看怎麼搭建和使用的詳細內(nèi)容。更多資訊請關注PHP中文網(wǎng)其他相關文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發(fā)現(xiàn)涉嫌抄襲或侵權的內(nèi)容,請聯(lián)絡admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動的應用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

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

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

使用Python開發(fā)微信小程式 使用Python開發(fā)微信小程式 Jun 17, 2023 pm 06:34 PM

隨著行動互聯(lián)網(wǎng)技術和智慧型手機的普及,微信成為了人們生活中不可或缺的一個應用。而微信小程式則讓人們可以在不需要下載安裝應用程式的情況下,直接使用小程式來解決一些簡單的需求。本文將介紹如何使用Python來開發(fā)微信小程式。一、準備工作在使用Python開發(fā)微信小程式之前,需要先安裝相關的Python函式庫。這裡推薦使用wxpy和itchat這兩個函式庫。 wxpy是一個微信機器

實作微信小程式中的卡片翻轉(zhuǎn)特效 實作微信小程式中的卡片翻轉(zhuǎn)特效 Nov 21, 2023 am 10:55 AM

實作微信小程式中的卡片翻轉(zhuǎn)特效在微信小程式中,實現(xiàn)卡片翻轉(zhuǎn)特效是一種常見的動畫效果,可以提升使用者體驗和介面互動的吸引力。以下將具體介紹如何在微信小程式中實現(xiàn)卡片翻轉(zhuǎn)的特效,並提供相關程式碼範例。首先,需要在小程式的頁面佈局檔案中定義兩個卡片元素,一個用於顯示正面內(nèi)容,一個用於顯示背面內(nèi)容,具體範例程式碼如下:<!--index.wxml-->&l

支付寶上線「漢字拾光-生僻字」小程序,用於徵集、補充生僻字庫 支付寶上線「漢字拾光-生僻字」小程序,用於徵集、補充生僻字庫 Oct 31, 2023 pm 09:25 PM

本站10月31日消息,今年5月27日,螞蟻集團宣布啟動“漢字拾光計劃”,最近又迎來新進展:支付寶上線“漢字拾光-生僻字”小程序,用於向社會徵集生僻字,補充生僻字庫,同時提供不同的生僻字輸入體驗,以幫助完善支付寶內(nèi)的生僻字輸入方法。目前,用戶搜尋「漢字拾光」、「生僻字」等關鍵字就可以進入「生僻字」小程式。在小程式裡,使用者可以提交尚未被系統(tǒng)辨識輸入的生僻字圖片,支付寶工程師確認後,將會對字庫進行補錄入。本站注意到,使用者也可以在小程式體驗最新的拆字輸入法,這項輸入法針對讀音不明確的生僻字設計。用戶拆

小程式能用react嗎 小程式能用react嗎 Dec 29, 2022 am 11:06 AM

小程式能用react,其使用方法:1、基於「react-reconciler」實作一個渲染器,產(chǎn)生一個DSL;2、建立一個小程式元件,去解析和渲染DSL;3、安裝npm,並執(zhí)行開發(fā)者工具中的建構npm;4、在自己的頁面中引入包,再利用api即可完成開發(fā)。

uniapp如何實現(xiàn)小程式和H5的快速轉(zhuǎn)換 uniapp如何實現(xiàn)小程式和H5的快速轉(zhuǎn)換 Oct 20, 2023 pm 02:12 PM

uniapp如何實現(xiàn)小程式和H5的快速轉(zhuǎn)換,需要具體程式碼範例近年來,隨著行動網(wǎng)路的發(fā)展和智慧型手機的普及,小程式和H5成為了不可或缺的應用形式。而uniapp作為一個跨平臺的開發(fā)框架,可以在一套程式碼的基礎上,快速實現(xiàn)小程式和H5的轉(zhuǎn)換,大大提高了開發(fā)效率。本文將介紹uniapp如何實現(xiàn)小程式和H5的快速轉(zhuǎn)換,並給出具體的程式碼範例。一、uniapp簡介unia

教你如何在小程式中用公眾號範本訊息(附詳細想法) 教你如何在小程式中用公眾號範本訊息(附詳細想法) Nov 04, 2022 pm 04:53 PM

這篇文章給大家?guī)砹岁P於微信小程式的相關問題,其中主要介紹瞭如何在小程式中用公眾號範本訊息,下面一起來看一下,希望對大家有幫助。

用Python編寫簡單的聊天程式教程 用Python編寫簡單的聊天程式教程 May 08, 2023 pm 06:37 PM

實現(xiàn)思路x01服務端的建立首先,在服務端,使用socket進行訊息的接受,每接受一個socket的請求,就開啟一個新的線程來管理訊息的分發(fā)與接受,同時,又存在一個handler來管理所有的線程,從而實現(xiàn)對聊天室的各種功能的處理x02客戶端的建立客戶端的建立就要比服務端簡單多了,客戶端的作用只是對消息的發(fā)送以及接受,以及按照特定的規(guī)則去輸入特定的字符從而實現(xiàn)不同的功能的使用,因此,在客戶端這裡,只需要去使用兩個線程,一個是專門用於接受消息,一個是專門用於發(fā)送消息的至於為什麼不用一個呢,那是因為,只

PHP與小程式的地理位置定位與地圖顯示 PHP與小程式的地理位置定位與地圖顯示 Jul 04, 2023 pm 04:01 PM

PHP與小程式的地理位置定位與地圖顯示地理位置定位與地圖顯示在現(xiàn)代科技中已經(jīng)成為了必備的功能之一。隨著行動裝置的普及,人們對於定位和地圖顯示的需求也越來越高。在開發(fā)過程中,PHP和小程式是常見的兩種技術選擇。本文將為大家介紹PHP與小程式中的地理位置定位與地圖顯示的實作方法,並附上對應的程式碼範例。一、PHP中的地理位置定位在PHP中,我們可以使用第三方地理位

See all articles