5分钟教你使用 console.log 管理你的输出日志

前言

在开发过程中,我们经常会使用 console.log 来输出一些信息,以便于我们调试。但是,当我们的项目越来越大,我们的 console.log 也会越来越多,这时候我们就需要对 console.log 进行管理,以便于我们更好的调试。

  • 以埋点为例子,本地开发中,我们一般是通过打印埋点来看是否生效,这时候埋点日志可能跟其它日志混在一起,我们很难找到我们想要的日志,这时候我们就需要对埋点日志进行管理,以便于我们更好的调试。
js 复制代码
logN.success("埋点", "page_click_report", {
    eventName: "page_click_report",
    params: {
        user_id: "linwu",
        age: "18",
        height: "171cm",
        sex: "male",
        wx: "linwu-hi"
    }
});
  • 版本号信息
  • 打印请求信息

有时候在混合H5开发的时候,接口并不是走XHR而是由客户端提供的JSBridge请求,这时候我们就要对log进行一些处理,以便于我们更好的调试。

Log函数

直接copy下面的代码到项目中,可以直接使用,童叟无欺啊亲

ts 复制代码
type Color = 'primary' | 'success' | 'info' | 'warning' | 'danger' | 'error';

const COLORS: Color[] = ['primary', 'success', 'info', 'warning', 'danger', 'error'];

const COLOR_MAP: Record<Color, string> = {
  primary: '#2d8cf0',
  success: '#19be6b',
  info: '#909399',
  warning: '#ff9900',
  danger: '#35495E',
  error:"#FF0000"
};

const getColor = (type: Color) => COLOR_MAP[type];

const createLog = <T extends any[]>(
  fn: (type: Color, ...args: T) => void
): Record<Color, (...args: T) => void> => {
  return COLORS.reduce((logs, type) => {
    logs[type] = (...args: T) => fn(type, ...args);
    return logs;
  }, {} as Record<Color, (...args: T) => void>);
};

const nsLog = (type: Color, ns: string, msg: string, ...args: any[]) => {
  const color = getColor(type);
  console.log(
    `%c ${ns} %c ${msg} %c ${args.length ? '%o' : ''}`,
    `background:${color};border:1px solid ${color}; padding: 1px; border-radius: 4px 0 0 4px; color: #fff;`,
    `border:1px solid ${color}; padding: 1px; border-radius: 0 4px 4px 0; color: ${color};`,
    'background:transparent',
    ...args
  );
};

export const logN = createLog(nsLog);

const sLog = (type: Color, msg: string, ...args: any[]) => {
  const color = getColor(type);
  console.log(
    `%c ${msg} ${args.length ? '%o' : ''}`,
    `color: ${color};`,
    ...args
  );
};

export const logS = createLog(sLog);

const bLog = (type: Color, msg: string, ...args: any[]) => {
  const color = getColor(type);
  console.log(
    `%c ${msg} ${args.length ? '%o' : ''}`,
    `background:${color}; padding: 2px; border-radius: 4px; color: #fff;`,
    ...args
  );
};

 export const logB = createLog(bLog);

示例

ts 复制代码
// Usage:
logS.primary("Primary message");
logN.success("接口", "https://api.juejin.cn/user_api/v1/user/get_info_pack",{
    "err_no": 0,
    "err_msg": "success",
    "data": {
        "user_basic": {
            "user_id": "3450719496318734",
            "user_name": "linwu",
            "company": "腾讯",
            "job_title": "高级前端开发工程师",
            "avatar_large": "https://p9-passport.byteacctimg.com/img/user-avatar/6c748ea6567c4afdd9f54dde04dbbfdf~300x300.image",
            "description": "☀高级前端开发工程师\r\n🌲就职于腾讯等多家互联网大厂\r\n📚《现代Javascript高级教程》、《现代Typescript高级教程》、《深入浅出Dart》作者",
            "favorable_author": 1,
            "builder": 0,
            "book_author": 0,
            "can_tag_cnt": 0,
            "is_select_annual": false,
            "select_annual_rank": 0,
            "annual_list_type": 0,
            "university": {
                "university_id": "0",
                "name": "",
                "logo": ""
            },
            "major": {
                "major_id": "0",
                "parent_id": "0",
                "name": ""
            },
            "student_status": 0,
            "study_point": 0,
            "identity": 0,
            "is_vip": false,
            "is_logout": 0,
            "become_author_days": 49
        },
        "user_counter": {
            "followee_count": 0,
            "follower_count": 620,
            "post_article_count": 110,
            "digg_article_count": 111,
            "got_digg_count": 2072,
            "got_view_count": 104959,
            "post_shortmsg_count": 3,
            "digg_shortmsg_count": 3,
            "select_study_event_count": 0,
            "select_online_course_count": 0,
            "collection_set_article_count": 29,
            "recommend_article_count_daily": 36,
            "got_article_collect_count_daily": 0
        },
        "user_growth_info": {
            "user_id": 3450719496318734,
            "jpower": 7711,
            "jscore": 813.2,
            "jpower_level": 5,
            "jscore_level": 5,
            "jscore_title": "先锋掘友",
            "author_achievement_list": [
                1
            ],
            "vip_level": 0,
            "vip_title": "",
            "jscore_next_level_score": 2000,
            "jscore_this_level_mini_score": 500,
            "vip_score": 0
        }
    }
});

logN.error("接口", "https://api.juejin.cn/user_api/v1/user/get_info_pack",{
    "err_no": 0,
    "err_msg": "fail",  
});


logB.info("VERSION v1.0.0");

小册

整理两本小册,一本是前端面试小册,一本是图解算法,阅读体验都很好,欢迎添加我微信linwu-hi获取

相关推荐
Bio Coder几秒前
学习用 Javascript、HTML、CSS 以及 Node.js 开发一个 uTools 插件,学习计划及其周期
javascript·学习·html·开发·utools
糊涂涂是个小盆友5 分钟前
前端 - 使用uniapp+vue搭建前端项目(app端)
前端·vue.js·uni-app
NMBG2213 分钟前
[JAVAEE] 面试题(四) - 多线程下使用ArrayList涉及到的线程安全问题及解决
java·开发语言·面试·java-ee·intellij-idea
浮华似水28 分钟前
Javascirpt时区——脱坑指南
前端
王二端茶倒水31 分钟前
大龄程序员兼职跑外卖第五周之亲身感悟
前端·后端·程序员
_oP_i36 分钟前
Web 与 Unity 之间的交互
前端·unity·交互
钢铁小狗侠38 分钟前
前端(1)——快速入门HTML
前端·html
凹凸曼打不赢小怪兽1 小时前
react 受控组件和非受控组件
前端·javascript·react.js
狂奔solar1 小时前
分享个好玩的,在k8s上部署web版macos
前端·macos·kubernetes
qiyi.sky1 小时前
JavaWeb——Web入门(8/9)- Tomcat:基本使用(下载与安装、目录结构介绍、启动与关闭、可能出现的问题及解决方案、总结)
java·前端·笔记·学习·tomcat