Login
芋圆社区 > 编程 > JavaScript > 定制Console.log

定制Console.log

622
0
2023-08-30
2023-08-30
Hey、小怪兽

  • • 从芋圆社区v3.0.5开始,打开F12控制台就可以看到定制的Console.log了:
  • • 首先需要了解Console.log的几个占位符:
  • - %o / %O:用于输出一个 JavaScript 对象的可展示形式。可以将 JavaScript 对象传递给 console.log 方法,并使用 %o 控制符以可读性更高的方式显示对象的内容
  • - %s:用于输出字符串。可以将字符串传递给 console.log 方法,并使用 %s 控制符将其插入到指定位置,作为字符串的展示形式
  • - %f:用于输出浮点数。可以将一个浮点数传递给 console.log 方法,并使用 %f 控制符进行格式化输出
  • - %c:用于设置输出文本的样式。可以通过在 %c 后面添加 CSS 样式规则来改变输出文本的样式
  • - %d / %i:打印整数。支持数字格式化。例如,console.log("Foo %.2d", 1.1) 会输出有先导 0 的两位有效数字:Foo 01(由于 1.1 不是一个整数,而是一个带有小数部分的浮点数,因此 %d 会截取其整数部分,并在输出时添加前导零,最后输出结果为 "Foo 01")
  • - \n:换行符,用于在输出中创建新的一行
  • • 了解完就可以写出芋圆社区这样的打印,首先先搞前面的芋头图标,将图片转成base64,用apply函数(可以直接复制下面的代码在控制台打印):
  • console.log.apply(console, ["\n%c  %c 芋圆社区 v" + "3.0.9" + " ✨\n",
    `background:url('') no-repeat; padding:1px 1px;background-size: 100% 100%;background-position: center;`, "color: #90430a;padding:5px 0;",]);
  • • 由此可以定制好多样子的Console.log,创建三个文件:console.js,index.js,index.html
  • • index.html引入这两个js:
  • <!DOCTYPE html>
    <html lang="en">
      <head>
        <meta charset="UTF-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <title>Document</title>
        <script src="./console.js"></script>
        <script src="./index.js"></script>
      </head>
      <body></body>
    </html>
  • • console.js写定制Console.log:
  • - 有三种类型的Console.log,分别是logN,logC,logB
  • - 接着是定义颜色,6种颜色:primary,success,default,info,warning,danger
  • - 然后是创建三个Console.log的方法
  • - 最后通过keys函数获取颜色的key值来遍历,创建每个类型不同颜色的Console.log
  • const logN = {};
    const logC = {};
    const logB = {};
    
    const CONSOLE_LOG_TYPE = {
      primary: "#50b5ff",
      success: "#19be6b",
      default: "#a09e9e",
      info: "#d592ff",
      warning: "#ff9900",
      danger: "#ff4729",
    };
    
    const createLogN = (color, ns, msg, ...args) => [`%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];
    
    const createLogC = (color, msg, ...args) => [`%c ${msg} ${args.length ? "%o" : ""}`, `color: ${color};`, ...args];
    
    const createLogB = (color, msg, ...args) => [`%c ${msg} ${args.length ? "%o" : ""}`, `background:${color}; padding: 2px; margin-right: 5px; border-radius: 4px; color: #fff;`, ...args];
    
    Object.keys(CONSOLE_LOG_TYPE).map((type) => {
      const color = CONSOLE_LOG_TYPE[type];
      logN[type] = (ns, msg, ...args) => createLogN(color, ns, msg, ...args);
      logC[type] = (msg, ...args) => createLogC(color, msg, ...args);
      logB[type] = (msg, ...args) => createLogB(color, msg, ...args);
    });
  • • 注意console.js里面并没有直接使用Console.log,因为考虑到要定位到打印的定位,需要外部调用,而这个JS文件只是创建样式而已,就是这个东西,好像叫SouceMap:
  • • 在index.js就可以直接调用了:
  • const obj = {
      name: "Taro",
      url: "www.inhami.com",
    };
    
    console.log(...logC.primary("Taro", obj));
    console.log(...logC.success("Taro", obj));
    console.log(...logC.default("Taro", obj));
    console.log(...logC.info("Taro", obj));
    console.log(...logC.warning("Taro", obj));
    console.log(...logC.danger("Taro", obj));
    
    console.log(...logN.success("v3.0.9", "Taro", obj));
    console.log(...logN.default("v3.0.9", "Taro", obj));
    console.log(...logN.info("v3.0.9", "Taro", obj));
    console.log(...logN.warning("v3.0.9", "Taro", obj));
    console.log(...logN.danger("v3.0.9", "Taro", obj));
    console.log(...logN.primary("v3.0.9", "Taro", obj));
    
    console.log(...logB.success("Taro", obj));
    console.log(...logB.default("Taro", obj));
    console.log(...logB.warning("Taro", obj));
    console.log(...logB.info("Taro", obj));
    console.log(...logB.danger("Taro", obj));
    console.log(...logB.primary("Taro", obj));
  • • 看到控制台成功打印,三种类型logN(Normal,最普通的),logC(Color,改变颜色的Console),logB(BackGround,改变背景的Console)
  • • 这里就会感觉到了,平时只需要打印一小串,而且有快捷指令clg,log啥的:
  • console.log()
  • • 现在要打印这么多:
  • console.log(...logN.success("v3.0.9", "Taro", obj));
  • • 没关系!也可以用快捷指令,用户代码片段,具体可以参考这篇博客:用户代码片段快速生成代码
  • • 我也贴上了代码片段,直接复制粘贴就可以:
  • {
      "console.log normal": {
        "prefix": "logn",
        "body": ["console.log(...logN.primary('$1', '$2', ${3}));"],
        "description": "vue3 ts snippet"
      },
      "console.log color change": {
        "prefix": "logc",
        "body": ["console.log(...logC.primary('$1', ${2}));"],
        "description": "vue3 ts snippet"
      },
      "console.log background-color change": {
        "prefix": "logb",
        "body": ["console.log(...logB.primary('$1', ${2}));"],
        "description": "vue3 ts snippet"
      },
    }
  • • 使用方法就输入logn,或者logc,或者logb
  • • 接着用tab键快速填充内容,如果需要修改颜色的话就去前面把primary改掉,默认是蓝色

上一篇:获取视频的第一帧

下一篇:WebAssembly简单案例

Message Board
回复
回复内容不允许为空
留言字数要大于2,小于200!
提交成功,5s后刷新页面!
编程导航

Array 基础方法

Array 进阶方法 - ES6

公主连结.cysp转.skel

获取视频的第一帧

定制Console.log

WebAssembly简单案例

一些常用的方法【持续更新】

AES加密 CBC模式

滚动条滚动到底部的判断

console.log展开值不一样

JSON解析与序列化

|| 运算符的坑

对象转为字符串

call,apply,bind

获取数组中对象的某一属性值

jQuery合并ajax请求

批量命名全局变量

forEach方法

round,ceil,floor

Copyright © 2020 芋圆社区

Powered by 浙ICP备2020039309号-1

此页面不支持夜间模式!

已进入夜间模式!

已进入普通模式!

搜索框不允许为空

签到成功!经验+5!芋圆币+2!

签到失败!今日已签到!

需要登录社区账号才可以进入!

复制成功
寄,页面未加载完成或页面无锚点