最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - Adding 'download' attribute to <a> dynamically using Jquery - Stack Overflow

programmeradmin3浏览0评论

I am trying to add the download attribute to an tag dynamically. Here is what I have so far:

$(fclass).append('<a href="/files/'+$days[$i][2][1]+'" download>'+$days[$i][2][0]+'</a>');

Which produces this:

<a href="/files/day0.pdf" download="">Slideshow (Notes)</a>

I also added the exact same tag as this produces into my HTML manually, but instead of

<a href="/files/day0.pdf" download="">

I used

<a href="/files/day0.pdf" download>

The manual version works perfectly, and automatically downloads the file, however, the dynamically placed version does not. I have also tried this:

$(a).attr("download","/files/day0.pdf");

But this does not seem to work. Any ideas on how to fix this? Thank you very much.

I am trying to add the download attribute to an tag dynamically. Here is what I have so far:

$(fclass).append('<a href="/files/'+$days[$i][2][1]+'" download>'+$days[$i][2][0]+'</a>');

Which produces this:

<a href="/files/day0.pdf" download="">Slideshow (Notes)</a>

I also added the exact same tag as this produces into my HTML manually, but instead of

<a href="/files/day0.pdf" download="">

I used

<a href="/files/day0.pdf" download>

The manual version works perfectly, and automatically downloads the file, however, the dynamically placed version does not. I have also tried this:

$(a).attr("download","/files/day0.pdf");

But this does not seem to work. Any ideas on how to fix this? Thank you very much.

Share Improve this question asked Jun 27, 2016 at 18:12 Trevor JudiceTrevor Judice 1371 gold badge1 silver badge10 bronze badges 6
  • You left the quotes out of $(a) – j08691 Commented Jun 27, 2016 at 18:17
  • @j08691 a is variable of a dynamically created <a> tag, not a single a element. – Trevor Judice Commented Jun 27, 2016 at 18:23
  • @PranavCBalan Still just links to the file, seems very odd. Not sure why, no download though. – Trevor Judice Commented Jun 27, 2016 at 18:24
  • $(a).attr("download","/files/day0.pdf"); assigns the url to download attribute. Aren't you trying to assign the url to href? – YSJ Commented Jun 27, 2016 at 18:24
  • @YSJ The download attribute is meant to just download the file without redirecting to a separate page. So, in doing so, you must reference the files within the download attribute. I also tried using href, and just setting download to a attribute with no parameters, however this does not work. – Trevor Judice Commented Jun 27, 2016 at 19:00
 |  Show 1 more ment

2 Answers 2

Reset to default 12

The answer is

$("a").attr("download", true);
<script src="https://ajax.googleapis./ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<a href="file-to-download.txt">Download the file</a>

Just checked an it is working :D

Did you try using Props ?

$(a).prop("download","/files/day0.pdf");

发布评论

评论列表(0)

  1. 暂无评论