console.log——NPM库

news2024/11/16 11:41:34

9a69fede8b2044a79dd834e3e48f20b4.png前期回顾   

Vue3 + TS 项目实战 - 后台管理系统 - 按钮权限_vue3+ts后台管理-CSDN博客

目录

🚩不使用NPM插件的方式

第一步:创建log函数-源码 

第二步:注册到window上

第三步:扩展Window接口

第四步:确保类型文件被TypeScript识别

第五步:使用window.log而不是log

 🤖 使用NPM库方式

第一步:使用 npm 安装

第二步:使用

 ❤️ 结语 


前言:控制台打印平平无奇,做一个美化的Hooks!

🚩不使用NPM插件的方式

第一步:创建log函数-源码 

位置:src\utils\Hooks\beautifyLog.ts

/**
 * 美化打印实现方法
 */
const prettyLog = () => {
	const isProduction =
		import.meta.env.MODE === "production" ||
		process.env.NODE_ENV === "production";

	const isEmpty = (value: any) => {
		return value == null || value === undefined || value === "";
	};
	const prettyPrint = (title: string, text: string, color: string) => {
		if (isProduction) return;
		console.log(
			`%c ${title} %c ${text} %c`,
			`background:${color};border:1px solid ${color}; padding: 1px; border-radius: 2px 0 0 2px; color: #fff;`,
			`border:1px solid ${color}; padding: 1px; border-radius: 0 2px 2px 0; color: ${color};`,
			"background:transparent"
		);
	};
	const info = (textOrTitle: string, content = "") => {
		const title = isEmpty(content) ? "Info" : textOrTitle;
		const text = isEmpty(content) ? textOrTitle : content;
		prettyPrint(title, text, "#909399");
	};
	const error = (textOrTitle: string, content = "") => {
		const title = isEmpty(content) ? "Error" : textOrTitle;
		const text = isEmpty(content) ? textOrTitle : content;
		prettyPrint(title, text, "#F56C6C");
	};
	const warning = (textOrTitle: string, content = "") => {
		const title = isEmpty(content) ? "Warning" : textOrTitle;
		const text = isEmpty(content) ? textOrTitle : content;
		prettyPrint(title, text, "#E6A23C");
	};
	const success = (textOrTitle: string, content = "") => {
		const title = isEmpty(content) ? "Success " : textOrTitle;
		const text = isEmpty(content) ? textOrTitle : content;
		prettyPrint(title, text, "#67C23A");
	};
	const table = (dataPaylod: Array<{}>) => {
		const data = dataPaylod;
		console.log(
			"%c id%c name%c age",
			"color: white; background-color: black; padding: 2px 10px;",
			"color: white; background-color: black; padding: 2px 10px;",
			"color: white; background-color: black; padding: 2px 10px;"
		);

		data.forEach((row: any) => {
			console.log(
				`%c ${row.id} %c ${row.name} %c ${row.age} `,
				"color: black; background-color: lightgray; padding: 2px 10px;",
				"color: black; background-color: lightgray; padding: 2px 10px;",
				"color: black; background-color: lightgray; padding: 2px 10px;"
			);
		});
	};
	const picture = (url: string, scale = 1) => {
		if (isProduction) return;
		const img = new Image();
		img.crossOrigin = "anonymous";
		img.onload = () => {
			const c = document.createElement("canvas");
			const ctx = c.getContext("2d");
			if (ctx) {
				c.width = img.width;
				c.height = img.height;
				ctx.fillStyle = "red";
				ctx.fillRect(0, 0, c.width, c.height);
				ctx.drawImage(img, 0, 0);
				const dataUri = c.toDataURL("image/png");

				console.log(
					`%c sup?`,
					`font-size: 1px;
                    padding: ${Math.floor(
											(img.height * scale) / 2
										)}px ${Math.floor((img.width * scale) / 2)}px;
                    background-image: url(${dataUri});
                    background-repeat: no-repeat;
                    background-size: ${img.width * scale}px ${
						img.height * scale
					}px;
                    color: transparent;
                    `
				);
			}
		};
		img.src = url;
	};

	return {
		info,
		error,
		warning,
		success,
		picture,
		table,
	};
};
export interface PrettyLogFunctions {
	info: (textOrTitle: string, content?: string) => void;
	error: (textOrTitle: string, content?: string) => void;
	warning: (textOrTitle: string, content?: string) => void;
	success: (textOrTitle: string, content?: string) => void;
	picture: (url: string, scale?: number) => void;
	table: (dataPaylod: Array<{}>) => void;
}
// 创建打印对象
const log = prettyLog();
export default log;

第二步:注册到window上

在main.ts文件中,确保您将log正确地绑定到了window对象上:

位置;main.ts

import log from './utils/Hooks/beautifyLog';
window.log = log;

第三步:扩展Window接口

在项目中创建一个新的TypeScript声明文件(例如src/types/env.d.ts),用于扩展全局Window对象的类型定义:

位置:src\types\global.d.ts

import { PrettyLogFunctions } from '../utils/Hooks/beautifyLog';

// 声明文件,*.vue 后缀的文件交给 vue 模块来处理
declare module '*.vue' {
	import type { DefineComponent } from 'vue';
	const component: DefineComponent<{}, {}, any>;
	export default component;
}

// 声明文件,定义全局变量
declare global {
	interface Window {
		log: PrettyLogFunctions;
	}
}

第四步:确保类型文件被TypeScript识别

"include": [
		"src/**/*.ts",
		"src/**/*.d.ts",
		"src/types/**/*.d.ts",
		"src/**/*.tsx",
		"src/**/*.vue",
		"src/views/visualLargeScreen/complianceRiskSituation/perfect-auto-screen-fit.js"
	],

第五步:使用window.log而不是log

<script setup>
import { onMounted } from 'vue';

onMounted(() => {
  window.log.info('Component mounted');
});
</script>

这样,您就可以在不引入任何额外模块的情况下,在全局范围内使用prettyLog的功能。

 window.log有以下方法:

         info,

        error,

        warning,

        success,

        picture,

        table,

 🤖 使用NPM库方式

第一步:使用 npm 安装

npm install pretty-log-plugin

第二步:使用

第一种方式 “引入”

import log from "pretty-log-plugin";
log.info("Hello, world!");

第二种方式:挂在window

参考上面

❤️ 结语 

7730e2bd39d64179909767e1967da702.jpeg

 _______________________________  期待再见  _______________________________

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1705794.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

leetcode 530.二叉搜索树的最小绝对差 、501.二叉搜索树中的众数 、236. 二叉树的最近公共祖先

leetcode 530.二叉搜索树的最小绝对差 、501.二叉搜索树中的众数 、236. 二叉树的最近公共祖先 leetcode 530.二叉搜索树的最小绝对差 题目链接&#xff1a;https://leetcode.cn/problems/maximum-binary-tree/description/ 题目&#xff1a; 给你一个二叉搜索树的根节点 r…

【Qt】Qt定时器类QTimer

在进行窗口程序的处理过程中, 经常要周期性的执行某些操作, 或者制作一些动画效果&#xff0c;看似比较复杂的问题使用定时器就可以完美的解决这些问题&#xff0c; Qt中提供了两种定时器方式一种是使用Qt中的事件处理函数这个在后续章节会给大家做细致的讲解&#xff0c;本节主…

常用目标检测预训练模型大小及准确度比较

目标检测是计算机视觉领域中的一项重要任务&#xff0c;旨在检测和定位图像或者视频中的目标对象。当人类观看图像或视频时&#xff0c;我们可以在瞬间识别和定位感兴趣的对象。目标检测的目标是使用计算机复制这种智能。 近年来&#xff0c;目标检测网络的发展日益成熟&#…

设计模式基础——设计原则介绍

1.概述 ​ 对于面向对象软件系统的设计而言&#xff0c;如何同时提高一个软件系统的可维护性、可复用性、可拓展性是面向对象设计需要解决的核心问题之一。面向对象设计原则应运而生&#xff0c;这些原则你会在设计模式中找到它们的影子&#xff0c;也是设计模式的基础。往往判…

力扣刷题--1528. 重新排列字符串【简单】

题目描述 给你一个字符串 s 和一个 长度相同 的整数数组 indices 。 请你重新排列字符串 s &#xff0c;其中第 i 个字符需要移动到 indices[i] 指示的位置。 返回重新排列后的字符串。 示例 1&#xff1a; 输入&#xff1a;s “codeleet”, indices [4,5,6,7,0,2,1,3] 输…

OpenMV的VisionBoard视觉识别开发板学习记录

此篇博客仅用于对VisionBoard的开发板的学习研究记录&#xff0c;没有教学内容。 一、资料来源 开发板资料链接 开发板环境搭建手册 开发板视频教程 板子的资料网站 openmv官方的网站 目录 一、资料来源二、针对 VisionBoard的目标识别和定位总结1. 目标识别功能1.1 物体检测…

大模型时代:生活将如何被重塑?

大模型时代&#xff1a;生活将如何被重塑&#xff1f; &#x1f604;生命不息&#xff0c;写作不止 &#x1f525; 继续踏上学习之路&#xff0c;学之分享笔记 &#x1f44a; 总有一天我也能像各位大佬一样 &#x1f3c6; 博客首页 怒放吧德德 To记录领地 &#x1f31d;分享…

数据挖掘与机器学习——回归分析

目录 回归分析定义&#xff1a; 案例&#xff1a; 线性回归 预备知识&#xff1a; 定义&#xff1a; 一元线性回归&#xff1a; 如何找出最佳的一元线性回归模型&#xff1a; 案例&#xff1a; python实现&#xff1a; 多元线性回归 案例&#xff1a; 线性回归的优缺…

Codeforces Round 948 (Div. 2) D. XORificator(哈希)

题目 n*m(n*m<3e5)的矩阵&#xff0c; 实际为t(t<1e4)组样例&#xff0c;但保证sum n*m不超过3e5 你可以选一行把所有01翻转&#xff0c;问最多可以让多少列只有一个1&#xff0c;然后把你翻转的行输出 思路来源 其实题还挺裸的&#xff0c;教了一下潘老师&#xff0…

8D和FMEA的关系是什么?——FMEA软件

免费试用FMEA软件-免费版-SunFMEA 在质量管理领域中&#xff0c;8D和FMEA是两个非常重要的工具。它们各自有着独特的作用&#xff0c;但同时又存在着紧密的联系。本文旨在深入探讨8D和FMEA之间的关系&#xff0c;以及它们如何协同工作以提高产品质量和客户满意度。 8D&#x…

【JavaEE精炼宝库】多线程(3)线程安全 | synchronized

目录 一、线程安全 1.1 经典线程不安全案例&#xff1a; 1.2 线程安全的概念&#xff1a; 1.3 线程不安全的原因&#xff1a; 1.3.1 案例刨析: 1.3.2 线程不安全的名词解释&#xff1a; 1.3.3 Java 内存模型 (JMM)&#xff1a; 1.3.4 解决线程不安全问题&#xff1a; 二…

紫光展锐前沿探索 | 满足未来6G多差异化应用场景的技术体系思考

在6G架构/系统设计中&#xff0c;紫光展锐提出了未来6G空口“一体多翼”的技术体系概念&#xff0c;即“Big-Lite Multi-RAT”。本文将详细对该技术体系展开介绍。 “一体多翼”技术体系通过 “体”&#xff08;Big RAT&#xff09;和“翼”&#xff08;Lite RAT&#xff09;的…

数据结构:树(2)【堆排序】【堆排序的时间复杂度】【topk】

一.堆排序 关于排序我们还是挺熟悉的&#xff0c;像是冒泡排序&#xff0c;快速排序等等。这里多介绍一种也挺牛的排序&#xff0c;叫做堆排序。在我的上一篇博客里我们了解到了关于堆的概念&#xff0c;堆又分为大堆和小堆。那么如果我们在进行堆排序的过程中&#xff0c;我们…

cs与msf权限传递,mimikatz抓取明文密码

目录 一、cs与msf权限传递 二、mimikatz抓取明文密码 一、cs与msf权限传递 cs传到msf&#xff1a; 创建foreign监听器-->msf监听模块设置端口-->cs执行新建会话选择创建的监听器 1.创建监听器&#xff1a; 2.msf监听设置端口&#xff1a; use exploit/multi/hander s…

计算机网络学习

文章目录 第一章信息时代的计算机网络因特网概述电路交换&#xff0c;分组交换&#xff0c;报文交换计算机网络的定义和分类计算机网络的性能指标常见的三种计算机网络体系计算机网络体系结构分层的必要性计算机网络体系结构分层思想举例计算机网络体系结构中的专用术语 第二章…

类别型特征

#机器学习 #深度学习 #基础知识 #特征工程 #数据编码 背景 在现实生活中,我们面对的数据类型有很多,其中有的数据天然为数值类型具备数值意义,那么可以很自然地和算法结合,但是大部分数据他没有天然的数值意义,那么将他们送入到算法前,就需要对数据进行编码处理,将其转换为数…

php -v在cmd中正常显示 在vscode中却报错

效果展示 原因 在vscode中 终端是 PowerShell PowerShell 默认情况下它不会继承系统的PATH环境变量 解决方案 使用CMD作为终端 打开VSCode设置&#xff08;File > Preferences > Settings 或 Ctrl,&#xff09;。搜索 terminal.integrated.shell.windows。更改其值…

vue3主题切换按钮与功能实现

代码: <template><div class"slideThree"><label class"theme-switch"><inputtype"checkbox"class"checkbox"v-model"isChecked"change"setTheme"id"slideThree"name"check…

光伏组件积灰检测系统

光伏组件积灰检测系统是一种专门用于监测光伏组件表面灰尘积累情况的设备。以下是关于该系统的详细信息和特点&#xff1a; 系统概述 光伏组件积灰检测系统安装在光伏板的框架上&#xff0c;通过实时监测光伏组件表面的灰尘厚度、分布情况和清洁度&#xff0c;为运维人员提供…

揭秘爬虫技术:从请求到存储的全方位解析

新书上架~&#x1f447;全国包邮奥~ python实用小工具开发教程http://pythontoolsteach.com/3 欢迎关注我&#x1f446;&#xff0c;收藏下次不迷路┗|&#xff40;O′|┛ 嗷~~ 目录 一、爬虫初探&#xff1a;请求与响应 二、数据解析&#xff1a;从混乱中提炼价值 三、数据…