如何在点击a标签下载文件的时候通过JavaScript动态的修改文件的名称?

如何在点击a标签下载文件的时候通过JavaScript动态的修改文件的名称?,第1张

<script type="text/javascript">

$("a").click(function () {

var href = this

var url = href.href

var name = href.innerHTML

if (url.indexOf("kindeditor") >= 0) {

download(url, name)

return false

}

})

/**

* 下载

* @param  {String} url 目标文件地址

* @param  {String} filename 想要保存中握的文件名称

*/

function download(url, filename) {

getBlob(url, function (blob) {

saveAs(blob, filename)

})

}

/**

* 获取 blob

* @param  {String} url 目标文件地址

* @return {cb}

*/

function getBlob(url, cb) {

var xhr = new XMLHttpRequest()

xhr.open('GET', url, true)

xhr.responseType = '袜培隐告厅blob'

xhr.onload = function () {

if (xhr.status === 200) {

cb(xhr.response)

}

}

xhr.send()

}

/**

* 保存

* @param  {Blob} blob   

* @param  {String} filename 想要保存的文件名称

*/

function saveAs(blob, filename) {

if (window.navigator.msSaveOrOpenBlob) {

navigator.msSaveBlob(blob, filename)

} else {

var link = document.createElement('a')

var body = document.querySelector('body')

link.href = window.URL.createObjectURL(blob)

link.download = filename

// fix Firefox

link.style.display = 'none'

body.appendChild(link)

link.click()

body.removeChild(link)

window.URL.revokeObjectURL(link.href)

}

}

</script>

可以合成一个大的Blob,再放到src上进行播放。

var theBigBlob = new Blob(blobsArr, {

type: "迹弯video/mp4"

})

document.getElementById("re-video").src = URL.createObjectURL(blob)

另外,请问你知道怎么只取一段blob吗,这链薯个blob数组只有从前面开棚州者始取才能播放,单个的好像不能播放,我想只取后面几个连续的一部分


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11988190.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-20
下一篇 2023-05-20

发表评论

登录后才能评论

评论列表(0条)

保存