当前位置: 首页 > 知识库问答 >
问题:

如何在单击HTML按钮或JavaScript时触发文件下载

车明贤
2023-03-14

这是疯狂的,但我不知道如何做到这一点,因为如何常见的词,很难找到我需要的搜索引擎。我想这应该是一个很容易回答的问题。

我想要一个简单的文件下载,这将做同样的如下:

<a href="file.doc">Download!</a>

但我想使用HTML按钮,例如:

<input type="button" value="Download!">
<button>Download!</button>

同样,是否可以通过JavaScript触发一个简单的下载?

$("#fileRequest").click(function(){ /* code to download? */ });

我绝对不是在寻找一种方法来创建一个看起来像按钮的锚,使用任何后端脚本,或者混乱服务器头或mime类型。

共有3个答案

夏涵畅
2023-03-14

HTML:

<button type="submit" onclick="window.open('file.doc')">Download!</button>
奚翰海
2023-03-14

您可以使用HTML5download属性触发下载。

<a href="path_to_file" download="proposed_file_name">Download</a>

其中:

  • path_to_file是解析为同一来源的URL的路径。这意味着页面和文件必须共享相同的域、子域、协议(HTTP vs.HTTPS)和端口(如果指定)。例外情况是blob:数据:(始终有效),以及文件:(从不有效)。
  • proposed_file_name是要保存到的文件名。如果为空,则浏览器默认为文件名。

文档:MDN、HTML标准on downloading、HTML标准ondownload、CanIUse

马臻
2023-03-14

你可以做的按钮

<form method="get" action="file.doc">
   <button type="submit">Download!</button>
</form>
 类似资料:
  • 问题内容: 这太疯狂了,但是我不知道该怎么做,而且由于这些单词很普遍,因此很难在搜索引擎上找到我需要的东西。我认为这应该很容易回答。 我想要一个简单的文件下载,该操作与此相同: 但是我想使用HTML按钮,例如以下任一按钮: 同样,是否可以通过JavaScript触发简单下载? 我绝对 不是 在寻找一种创建类似于按钮的锚,使用任何后端脚本或与服务器标头或mime类型混淆的方法。 问题答案: 对于按钮

  • 我找到了其他相关的问题,但没有一个答案实际上解决了我的问题。这个按钮在IE上很好用,但在Chrome上不行。我尝试移除span元素,将按钮放在任何其他标记之外,但仍然触发了两次。这个temple扩展了一个'base.html'文件,代码位于'main'元素中。 HTML: jQuery:

  • 我在一个页面上有几个html控件和一个搜索按钮。当用户在输入控件之外时(即焦点不在输入控件内),如果用户按enter键,我想触发搜索按钮的单击事件。搜索按钮不是按钮,也不在内 目前我正在做这个

  • 问题内容: 似乎是一个简单的问题,但解决其他问题的方法似乎对我没有用。 试图通过单击按钮来触发AJAX请求,但似乎并未触发。 HTML示例 javascript 问题答案: 您拥有的代码在拨弄中工作得很好。初始页面加载后,按钮是否通过AJAX动态呈现? 用 代替

  • 问题内容: 这是我想做的事情:单击页面上的一个按钮,这又使(2)事情发生: 显示一个ModalPopup,以防止用户按下任何按钮或更改值 在方法后面调用我的代码,完成后隐藏ModalPopup 这是ASP标记: 现在,这是我在C#代码后面的代码: 为什么不起作用?ModalPopup可以完美显示,但是btnSaveData_Click事件从不触发。 更新: 第一个建议对我不起作用。我还尝试了您的第

  • PayPal Checkout按钮点击本身打开PayPal安全窗口,其余工作正常。当客户点击第一个单选按钮时,我想再次打开PayPal安全窗口,即触发点击PayPal结账按钮。如果按钮本身出现在iframe中,而我无法触发该按钮跨域的单击事件,我该怎么做?有没有办法触发签出按钮的点击? 这里是超文本标记语言代码: 和Javascript代码: 编辑:作为一个工作的例子,我会建议这个网站,但这是有点