首頁 > 軟體

行動端偵錯神器vConsole使用詳解

2022-04-16 13:00:30

介紹

平時在web應用開發過程中,我們可以console.log去輸出一些資訊或者看介面返回的資訊及介面效能等情況,但是在行動端,也就是在手機上,我們是看不到的。

這種情況下,可以選擇使用alert彈出一些資訊,但是這種方法不怎麼方便,也會阻斷JS執行緒,導致後面的執行緒都不執行。也影響偵錯體驗。

那麼,如果將console.log應用到行動端呢?
需要藉助第三方外掛:vConsole

一個輕量、可拓展、針對手機網頁的前端開發者偵錯面板。

vConsole 是框架無關的,可以在 Vue、React 或其他任何框架中使用。都有配套外掛

https://gitee.com/Tencent/vConsole/tree/master/ 官方檔案

功能特性

紀錄檔(Logs): console.log|info|error|…
網路(Network): XMLHttpRequest, Fetch, sendBeacon
節點(Element): HTML 節點樹
儲存(Storage): Cookies, LocalStorage, SessionStorage
手動執行 JS 命令列
自定義外掛

使用

方法一:使用 npm(推薦)

npm install vconsole

Import 並初始化後,即可使用 console.log 功能,如 Chrome devtools 上一樣。

import VConsole from 'vconsole';
const vConsole = new VConsole();
// 接下來即可照常使用 `console` 等方法
console.log('Hello world');
// 結束偵錯後,可移除掉
vConsole.destroy();

方法二:使用 CDN 直接插入到 HTML

<script src="https://unpkg.com/vconsole@latest/dist/vconsole.min.js"></script>
<script>
  // VConsole 預設會掛載到 `window.VConsole` 上
  var vConsole = new window.VConsole();
  // 接下來即可照常使用 `console` 等方法
	console.log('Hello world');
	
	// 結束偵錯後,可移除掉
	vConsole.destroy();
</script>

開發環境顯示生成環境刪除

首先,咱們在做react、vue的單頁應用開發的時候,相信大家對組態檔裡的process.env並不眼生。 我們只需要生產環境不載入vConsole 開發和測試載入vConsole 並且限制只在手機端顯示,因為pc有遊覽器的偵錯工具了,如果條件允許我們還可以新增生產環境開關按鈕的方式觸發偵錯面板

vue案例

如果不懂process.env的話自行百度搜尋下很簡單的,就好比全域性變數一樣

在main.ts裡面新增如下程式碼

import { createApp } from 'vue'
import App from './App.vue'
import './registerServiceWorker'
import store from './store'
import VConsole from 'vconsole';
import router from './router'
createApp(App).use(store).use(router).mount('#app')

// 判斷是否是pc裝置
const isPc = () => {
    const userAgentInfo = navigator.userAgent;
    const Agents = ["Android", "iPhone",
        "SymbianOS", "Windows Phone",
        "iPad", "iPod"];
    let flag = true;
    for (let v = 0; v < Agents.length; v++) {
        if (userAgentInfo.indexOf(Agents[v]) > 0) {
            flag = false;
            break;
        }
    }
    return flag;
}

//如果不是生產環境並且不是pc裝置那麼就顯示偵錯
if (process.env.NODE_ENV != "prod" && !isPc()) {
    console.log(process.env.NODE_ENV);
    const vConsole = new VConsole();
}


到此這篇關於行動端偵錯神器vConsole的文章就介紹到這了,更多相關行動端偵錯vConsole內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com