在 ora 源码分析 ———— ora 怎么实现的? 这篇文章中有提到过 cli-spinners 这个库,它也是 ora 的核心物料库,提供着 ‘定格动画中的每一帧画面’。
Github 是这样描述的
The list of spinners is just a JSON file and can be used wherever.
You probably want to use one of these spinners through the ora module.
作者将它描述为一个 JSON 形式的列表,并且推荐你可以通过 ora 来使用它
示例
作者给了一个综合性的示例。展示了大概一半的效果。
data:image/s3,"s3://crabby-images/4014c/4014c5023f57faff0379b43e20eea130d5a03822" alt="screenshot.gif"
我选择了其中几个有意思的物料库运行了一下
import ora from 'ora'
const spinerList = [
'timeTravel',
'speaker',
'soccerHeader',
'fistBump',
'weather',
'moon',
'earth',
'smiley']
let index = 0
const spinner = ora({
prefixText: 'spinnerName:‘timeTravel’',
spinner: 'timeTravel'
}).start()
setInterval(function(){
spinner.prefixText = `spinnerName: timeTravel`
spinner.spinner = spinerList[index]
index = ++index % spinerList.length;
}, 1500)
效果如下
data:image/s3,"s3://crabby-images/27ae7/27ae791866c2e7c125f73e8061fd74d996339a62" alt="屏幕录制2022-01-23 上午10.gif"
data:image/s3,"s3://crabby-images/9029d/9029de943f64c466caaa7fce488c952b4ffae18d" alt="image.png"
文件结构为
interval:刷新的速度,毫秒单位
frames:每一步的动作字符
看起来很简单是不是,接下来我们来试一下自己制作物料
自制物料
字符来源
有很多字符网站,例如:https://cn.piliapp.com/symbol/ ,也可以通过一些字符制作网站,制作自己的一套字符,用在自己的 npm 包的制作中,一个字,就是玩~
效果
data:image/s3,"s3://crabby-images/2d50e/2d50ee18b856649bb3c2e0ab891307275be02cde" alt="1.gif"
data:image/s3,"s3://crabby-images/e0bdf/e0bdf254df2d1938c17e369d710a6eab620e8e79" alt="2.gif"
代码如下
友好提示:写动作字符会上瘾 🤪
var kou = {
interval: 200,
frames: [
'口',
'回',
'口',
'回',
]
}
var circle = {
interval: 80,
frames: [
'?',
'?',
'?',
'?',
]
}
var kungfu = {
interval: 200,
frames: [
'?',
'?',
'?',
'?',
]
}
var composite = {
interval: 300,
frames: [
'? ● ?',
'? ?? ?',
'? ? ? ?',
'? ? ? ?',
'?? ??',
'● ●',
'?? ??',
'? ? ? ?',
'? ?? ?',
]
}
var omit = {
interval: 200,
frames: [
'.',
' .',
' .',
' .',
' .',
'. .',
' . .',
' . .',
' ..',
'. ..',
' . ..',
' ...',
'. ...',
' ....',
'.....',
'!....',
'.!...',
'..!..',
'...!.',
'....!',
'!...!',
'.!..!',
'..!.!',
'...!!',
'!..!!',
'.!.!!',
'..!!!',
'!.!!!',
'.!!!!',
'!!!!!',
'.!!!!',
'!.!!!',
'!!.!!',
'!!!.!',
'!!!!.',
'.!!!.',
'!.!!.',
'!!.!.',
'!!!..',
'.!!..',
'!.!..',
'!!...',
'.!...',
'!....',
'.....',
'. ...',
'.. ..',
'... .',
'.... ',
' ... ',
'. .. ',
'.. . ',
'... ',
' .. ',
'. . ',
'.. ',
' . ',
]
}
const spinerList = [
kou,
circle,
kungfu,
composite,
omit
]
let index = 0
const spinner = ora({
spinner: kou,
}).start()
setInterval(function(){
spinner.spinner = spinerList[index]
index = ++index % spinerList.length
}, 2000)
文章来自公众号:前端学海
|