国产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 ( 實時日志 )

官方并沒有介紹兩者的具體區(qū)別,只是強調(diào)了 Realtime 的實時性質(zhì)。

在我看來他們的最大區(qū)別就是:

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

LogManager

小程序提供的 Log 日志接口,通過 wx.getLogManager() 獲取實例。
注意:

  • 最多保存5M的日志內(nèi)容,超過5M后,舊的日志內(nèi)容會被刪除。
  • 對于 小程序 ,用戶可以通過使用?button?組件的?open-type="feedback"?來上傳打印的日志。
  • 對于 小游戲 ,用戶可以通過使用?wx.createFeedbackButton?來創(chuàng)建上傳打印的日志的按鈕。
  • 開發(fā)者可以通過小程序管理后臺左側(cè)菜單 反饋管理 頁面查看相關打印日志。

創(chuàng)建 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)舊版本問題在新代碼中找不到問題
  • 兼容性:我們需要考慮用戶小程序版本不足以支持 getLogManager 、 getRealtimeLogManager 的情況
  • 類型:我們需要兼容 debuglog 、 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 、 logerror 類型的 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)其他相關文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻,版權歸原作者所有,本站不承擔相應法律責任。如您發(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是一個微信機器

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

實現(xiàn)微信小程序中的卡片翻轉(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”實現(xiàn)一個渲染器,生成一個DSL;2、創(chuàng)建一個小程序組件,去解析和渲染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)換,需要具體代碼示例近年來,隨著移動互聯(liá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與小程序中的地理位置定位與地圖顯示的實現(xiàn)方法,并附上相應的代碼示例。一、PHP中的地理位置定位在PHP中,我們可以使用第三方地理位

See all articles