当前位置:网站首页>命令行加载特效 【cli-spinner.js】 实用教程
命令行加载特效 【cli-spinner.js】 实用教程
2022-08-03 08:36:00 【朝阳39】
cli-spinner 官网
https://www.npmjs.com/package/cli-spinner
创建 cli-spinner 的演示项目
- 新建文件夹 cli-spinnerDemo
- 在 cli-spinnerDemo文件夹中打开命令行,执行
npm init -y
会自动生成 package.json
- 安装 cli-spinner
cnpm i cli-spinner
无 cnpm 的朋友先执行 npm i cnpm
- 在package.json中添加项目启动脚本
"start": "node index.js",
- 在 cli-spinnerDemo文件夹中新建文件 index.js 内容为
let Spinner = require("cli-spinner").Spinner;
let spinner = new Spinner("processing.. %s");
spinner.setSpinnerString("|/-\\");
spinner.start();
- 启动项目
npm run start
效果如下
导入 cli-spinner
let Spinner = require("cli-spinner").Spinner;
使用 cli-spinner
自定义加载提示文字
let spinner = new Spinner("加载中.. %s");
配置加载特效
spinner.setSpinnerString("|/-\\");
加载特效通过循环遍历字符串 |/-\\
实现,可以自定义为其他字符串。
启动加载
spinner.start();
停止加载
spinner.stop(true);
有参数 true 时,停止加载后,会清除加载提示文字,若无参数,则会保留加载提示文字
封装延时函数
为了看清加载特效,通常会延时1s左右再关闭加载特效,可使用以下函数实现
function sleep(timeout = 1000) {
return new Promise((resolve) => setTimeout(resolve, timeout));
}
使用方式如下:
let Spinner = require("cli-spinner").Spinner;
let spinner = new Spinner("加载中.. %s");
spinner.setSpinnerString("|/-\\");
(async function () {
// 开启加载特效
spinner.start();
// 延时2s
await sleep(2000);
// 关闭加载特效;
spinner.stop(true);
})();
function sleep(timeout = 1000) {
return new Promise((resolve) => setTimeout(resolve, timeout));
}
完整演示范例
let Spinner = require("cli-spinner").Spinner;
let spinner = new Spinner("加载中.. %s");
spinner.setSpinnerString("|/-\\");
// 开启加载特效
spinner.start();
// 1s后关闭加载特效
setTimeout(() => {
spinner.stop(true);
}, 1000);
更多功能
可参考官网,或留言我来添加哈!
边栏推荐
- 基于二次型性能指标的燃料电池过氧比RBF-PID控制
- mysql服务器上的mysql这个实例中表的介绍
- 行业洞察 | 如何更好的实现与虚拟人的互动体验?
- Guava的Service
- 【论文笔记】一种基于启发式奖赏函数的分层强化学习方法
- CSP-S2019 Day2
- The Transformer, BERT, GPT paper intensive reading notes
- LINGO 18.0软件安装包下载及安装教程
- ArcEngine (4) Use of MapControl_OnMouseDown
- How does Mysql query two data tables for the same fields in two tables at the same time
猜你喜欢
随机推荐
线性表
Nacos使用实践
《剑指Offer》刷题之打印从1到最大的n位数
使用pipreqs导出项目所需的requirements.txt(而非整个环境)
【TPC-DS】DF的SQL(Data Maintenance部分)
C# 一周入门高级编程之《C#-继承》Day One
scala 并行集合、并行并发、线程安全问题、ThreadLocal
Logic Pro X built-in sound library list
mysql的innodb存储引擎和myisam存储引擎的区别
NFT到底有哪些实际用途?
Guava-字符串工具
HCIP练习03(重发布)
dflow入门3——dpdispatcher插件
ArcEngine(三)通过MapControl控件实现放大缩小全图漫游
批量将PNG格式转化为JPG格式
dflow入门5——Big step & Big parameter
QT中线程调用GUI主线程控件的问题
AI中台序列标注任务:三个数据集构造过程记录
Arduino框架下对ESP32 NVS非易失性存储解读以及应用示例
服务器资源监控工具-nmon、nmon_analyser