b-zhan脚本更新
关注不迷路
api及参数说明来自 https://zhuanlan.zhihu.com/p/210779665
gitee项目地址https://gitee.com/z2322739526/mybilibili
脚本greasyfork地址 https://greasyfork.org/zh-CN/scripts/444136-mybilibili
原脚本现状
没办法不能直接打开,只能采用blob的请求格式了
if(con == true){
//
// 文件流可以自定义文件名,但是反馈太慢了,暂不采用
var x = new XMLHttpRequest()
// 设置xhr监听函数
x.addEventListener('progress', downloadProgress);
x.open("GET", vurl, true)
x.responseType = 'blob'
x.onload=function(e) {
//会创建一个 DOMString,其中包含一个表示参数中给出的对象的URL。这个 URL 的生命周期和创建它的窗口中的 document 绑定。这个新的URL 对象表示指定的 File 对象或 Blob 对象。
var url = window.URL.createObjectURL(x.response)
var a = document.createElement('a')
a.href = url
a.download = name+'.flv';
a.click()
}
x.send()
//
// 普通新页面下载
//window.open(vurl,'_self');
}
幸好留了一手,除了下载反馈慢了点其他不影响
2022.12.31更新版本0.3.6
加入xhr事件监听,用于更新下载进度,并通过Date.now()差值设置每0.5s更新一次
// 设置xhr监听函数
x.addEventListener('progress', downloadProgress);
// 请求事件监听(每0.5s输出一次)
var ms= 500;
var lastClick = Date.now() - ms;
function downloadProgress(event) {
// 如果lengthComputable属性的值是false,那么意味着总字节数是未知并且total的值为零
if (event.lengthComputable && Date.now() - lastClick >= ms) {
let progress = event.loaded / event.total * 100;
console.log('加载进度' + progress + '%');
// 更新时间
lastClick = Date.now();
}
}