调用浏览器另存为,实现视频下载

本文介绍了一种在浏览器中实现视频文件下载的方法,通过JavaScript创建虚拟链接并触发点击事件,解决了直接在浏览器中打开而非下载的问题,适用于火狐和谷歌浏览器。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近有一个需求,要下载视频,用户上传的视频放在视频服务器,然后php返回的url在浏览器href后并没有开始下载,而是直接打开了。

原因是服务器上有此视频,返回的url被浏览器解析到视频源文件,浏览器可以识别到视频,就会直接打开。

所以想到用浏览器的另存为来实现下载。(兼容火狐与谷歌)

 function fake_click(obj) {
        var ev = document.createEvent("MouseEvents");
        ev.initMouseEvent(
            "click", true, false, window, 0, 0, 0, 0, 0
            , false, false, false, false, 0, null
        );
        obj.dispatchEvent(ev);
    }

    function export_raw(name, data) {
        var save_link = document.createElementNS("http://www.w3.org/1999/xhtml", "a");
        save_link.href = data;
        save_link.download = name;
        fake_click(save_link);
    }
export_raw("ee59cf02cf7939a403e7db97368ee6e5.ogv",data);

 

转载于:https://www.cnblogs.com/xwtbk/p/6972159.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值