create-vue源码学习之 gradient-string 渐变色打印

效果

在使用 create-vue 脚手架时,想实现如下的打印效果。
在这里插入图片描述

探究过程

翻到源码里看到这一行
没错,绿色部分就是告诉我们如何生成的。可以看到引入了 gradient-string 包
在这里插入图片描述
于是乎,我来试试

pnpm i gradient-string    
pnpm i --save-dev @types/gradient-string
import gradient from 'gradient-string'async function init() {console.log()// process.stdout.isTTY 检查终端是否支持彩色输出// process.stdout.getColorDepth() > 8  检查终端的颜色深度。颜色深度通常以位(bit)为单位,8位表示256色,24位表示真彩色。console.log(process.stdout.isTTY && process.stdout.getColorDepth() > 8? banners.gradientBanner: banners.defaultBanner)console.log()let coolGradient = gradient([{ color: '#42d392', pos: 0 },{ color: '#42d392', pos: 0.1 },{ color: '#647eff', pos: 1 }])('Vue.js - The Progressive JavaScript Framework')console.log('🚀 ~ coolGradient:', coolGradient)
}init().catch((e) => {console.error(e)
})

看看打印结果:
在这里插入图片描述

可是我也不想引入包,想直接输出一串 ANSI 转义码,咋办?

先来分析下 create-vue 源码的这段 ANSI 转义码
在这里插入图片描述

在终端中,ANSI 转义码用于控制文本的颜色、背景色、样式等。这些转义码以 \x1B[ 开头,后面跟着一系列参数,最后以 m 结束。例如,\x1B[38;2;66;211;146m 表示设置前景色为 RGB(66, 211, 146)。其中红色标注的部分为我们要打印的文本 “Vue”。

愣是没找到合适的打印方法,突然想起一个骚操作那就是,encodeURI(coolGradient) ,来试试看
在这里插入图片描述
可以看到除了 %1B%5B,其他都一样,那就来个全局替换 %1B%5B --> \x1B[

console.log('🚀 ~ coolGradient:', encodeURI(coolGradient).replaceAll('%1B%5B', '\x1B['))

打印结果
在这里插入图片描述
这里 %20 就是空格啦,同样的思路,全局替换下就可以了。

这时候我们就可以拿到打印的字符串结果,去替换引入的 gradient-string 包啦。

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

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

相关文章

【IT人生系列二】第一次离职你下定了什么决心

本文承接【IT人生系列一】你的第一份工作激起了多少浪花 转眼间,博主已经在java这趟列车上漂流了18个月之久,再美的风景也会厌倦,我也不是那个初到上海充满干劲的少年,理想与现实的落差让我越发迷茫,我无数次想过放弃…

怎么在PPT插入视频?3个做PPT常用的使用技巧分享!

PPT技巧在日常办公中扮演着重要角色,ppt是一个开放的视觉呈现工具和载体,它支持在页面中插入各种内容媒介,包括文本、图片、视频、音频、矢量素材等,特别是当涉及到PPT插入视频时,它的作用就显得尤为突出。 不过说到p…

ASP.NET Web Api 使用 EF 6,DateTime 字段如何取数据库服务器当前时间

前言 在做数据库设计时,为了方便进行数据追踪,通常会有几个字段是每个表都有的,比如创建时间、创建人、更新时间、更新人、备注等,在存储这些时间时,要么存储 WEB 服务器的时间,要么存储数据库服务器的时间…

计算机三级嵌入式笔记(二)——嵌入式处理器

目录 考点1 嵌入式处理器的结构类型 考点2 嵌入式处理器简介 考点3 ARM处理器概述 考点4 处理器和处理器核 考点5 ARM 处理器的分类 考点6 经典 ARM 处理器 考点7 ARM Cortex 嵌入式处理器 考点8 ARM Cortex实时嵌入式处理器 考点9 ARM Cortex 应用处理器 考点10 AR…

Linux--Socket编程预备

目录 1. 理解源 IP 地址和目的 IP 地址 2.端口号 2.1端口号(port)是传输层协议的内容 2.2端口号范围划分 2.3理解 "端口号" 和 "进程 ID" 2.4理解 socket 3.传输层的典型代表 3.1认识 TCP 协议 3.2认识 UDP 协议 4. 网络字节序 5. socket 编程接…

应用产品的通信测试

当前所在公司为物联网产品,研发端没有真正的通信协议栈自主研发、也没有真正懂协议及协议实现的人。基本都是靠着供应商的指导和定位在做通信类开发。但日常中遇到的问题确实很细很底层的,特别是对研发和测试人员来说,遇到一个问题肯定是希望…

【数据结构】包装类、初识泛型

🎇🎉🎉🎉点进来你就是我的人了 博主主页:🙈🙈🙈戳一戳,欢迎大佬指点! 人生格言: 当你的才华撑不起你的野心的时候,你就应该静下心来学习! 欢迎志同道合的朋友…

Selenium之execute_script()方法执行js脚本

目录 场景应用和使用 页面滚动 获取返回值 返回JavaScript定位的元素对象 修改元素属性 弹出提示框 场景应用和使用 在自动化测试中,部分场景无法使用自动化Selenium原生方法来进行测试: 滚动到某个元素(位置) 修改…

Unity UGUI 之 Slider

本文仅作学习笔记与交流,不作任何商业用途 本文包括但不限于unity官方手册,唐老狮,麦扣教程知识,引用会标记,如有不足还请斧正 1.Slider是什么 滑块,由三部分组成:背景 填充条 手柄 填充条就是…

【打工日常】使用Prometheus+Grafana+Alertmanager+Webhook-dingtalk搭建监控平台

一、监控平台介绍1.监控平台简述普罗米修斯四件套,分别为Prometheus、Grafana、Alertmanager、Webhook-DingTalk。Prometheus一套开源的监控&报警&时间序列数据库的组合,由SoundCloud公司开发,广泛用于云原生环境和容器化应用的监控和性能分析。其提供了通用的数据模…

《昇思 25 天学习打卡营第 20 天 | Pix2Pix实现图像转换 》

《昇思 25 天学习打卡营第 20 天 | Pix2Pix实现图像转换 》 活动地址:https://xihe.mindspore.cn/events/mindspore-training-camp 签名:Sam9029 Pix2Pix模型概述 Pix2Pix是一种基于条件生成对抗网络(cGAN)的图像转换模型&#x…

无人机侦察:一维相扫雷达技术详解

一维相扫雷达技术,即相位扫描雷达技术,在无人机侦察中扮演着重要角色。该技术通过在雷达发射天线上施加变化的相位差,使天线波束在固定平面内进行一维扫描,从而实现对目标区域的搜索和跟踪。与传统的机械扫描雷达相比,…

本地部署SearXNG

SearXNG SearXNG 是一个免费的互联网元搜索引擎,整合了各种搜索服务的结果。用户不会被跟踪,也不会被分析。 1. 使用 Docker 安装 SearXNG 容器 复制 docker run --rm \-d -p 8080:8080 \-v "${PWD}/searxng:/etc/searxng" \-e "BASE_…

leetcode.nvim使用cookie无法登陆问题

错误描述: 使用力扣 (LeetCode) 全球极客挚爱的技术成长平台 的cookie在neovim上使用leetcode.nvim进行登录会出现curl xxx -D xxxx的报错。 解决方法: 使用LeetCode - The Worlds Leading Online Programming Learning Platform这个网站的cookie进行登…

hisilicon的APP开发

hisilicon的APP开发 hisilicon的APP开发1、在andorid 源码目录对第三方apk进行签名:2、命令启动app应用3、查看SELinux当前状态:4、梯形接口 1、在andorid 源码目录对第三方apk进行签名: 参考:Technology\android\生成系统签名.md java -Xmx2048m -Djava.library.path=&…

Vishay推出具有高辐射强度和短开关时间的新型890 nm红外发光二极管

高速器件采用表面发射器芯片技术,优异的VF温度系数达 -1.0 mV/K 美国 宾夕法尼亚 MALVERN、中国 上海 — 2024年7月24日 — 日前,威世科技Vishay Intertechnology, Inc.(NYSE 股市代号:VSH)宣布,推出一款采…

dorado7 打印校验失败的字段

// Bind #updateTrade.beforeExecute !function(self, arg, dsTrade) { var currentData dsTrade.get("data:#"); if (currentData ! undefined) { var context {}; //校验时传入一个context 打印的时候能把校验出错的字段打印出来 var state currentData.v…

FTP、NFS、SAMBA系统服务

⼀、rsync托管xinetd 1 、为什么要进⾏服务托管 独⽴服务:独⽴启动脚本 ssh ftp nfs dns ... 依赖服务 : 没有独⽴的启动脚本 rsync telnet 依赖 xinetd 服务(独⽴服务) 2 、如何将 rsync 托管给 xinetd 服务去管理? 第⼀步&am…

普发Pfeiffer TPG300手侧配置安装操作技术资疗包含

普发Pfeiffer TPG300手侧配置安装操作技术资疗包含

Spring WebFlux 介绍与效果演示示例

Spring WebFlux 是 Spring Framework 5 引入的一个新的 Web 框架,它专为构建反应式(Reactive)Web 应用程序而设计。以下是对 Spring WebFlux 的详细介绍和示例。 Spring WebFlux 介绍 响应式编程: Spring WebFlux 使用响应式编程的理念,其中数据流和异步操作是核心概念。…