我有一个简单的html网站,顶部是带有下载按钮的主图像。 下载使用html5下载属性。
现在我在主图像下面有一些缩略图 - 点击时用缩略图替换主图像。
以下问题:我使用相同的JavaScript代码也用缩略图网址替换下载按钮的网址,但是当点击下载按钮时,它仍然会从html打开硬编码的下载链接,而不是使用替换的网址。< / p>
HTML
<div class="dwnldcntnr">
<img src="imgage1.jpg" alt="Image Title 1" />
</div>
<div id="btncntnr">
<a href="imgage/image1.jpg" download="image1.jpg">
<button id="btn">Download</button></a>
</div>
<div class="itemcntnr">
<a href="image2.jpg" title="2.jpg">
<img src="image2.jpg" />
</a></div>
使用缩略图网址替换下载网址的JS代码
<script type="text/javascript">
$(document).ready(function() {
$('.itemcntnr a').click(function() {
var path = $(this).attr('href');
$('#btncntnr a').attr('href', path)
.attr('download', $('a', this).attr('title'));
return false;
});
});
</script>
答案 0 :(得分:0)
尝试替换整个DOM元素。
我认为您不应该在button
标记内嵌套a
,因为它们都是具有本机交互性的元素。您很可能在早期版本的IE中遇到HTML解析错误。
$('.itemcntnr a').click(function() {
var $this = $this.clone().empty().html('Download');
$('#btncntnr a').replaceWith($this);
return false;
});
答案 1 :(得分:0)
请勿在html中为链接添加硬编码href,而是尝试在$(document).ready
上添加
我同意你不应该将button
放在a
标签内。而是将样式应用于a
标记,使其看起来像一个按钮