在Firefox上使jQuery单击锚点工作

时间:2015-01-07 07:00:46

标签: javascript jquery firefox cross-browser

我有这个脚本:

function downloadIt() {
  var dataUri = "data:application/csv;charset=utf-8,Col1%2CCol2%2CCol3%0AVal1%2CVal2%2CVal3%0AVal11%2CVal22%2CVal33%0AVal111%2CVal222%2CVal333"
  var filename = "somedata.csv"
  $("<a download='" + filename + "' href='" + dataUri + "'></a>")[0].click();
}

它可以在Chrome上运行,但在Firefox上不起作用,控制台上没有任何错误。原因是什么以及如何解决这个问题?

1 个答案:

答案 0 :(得分:4)

body上附加元素可以解决问题,只需将上面问题中的行3替换为:

// store the element to a variable
var x = $("<a download='" + filename + "' href='" + dataUri + "'></a>");

// append to body
x.appendTo('body');

// click it (download)
x[0].click();

// remove from body
x.remove();

当元素未附加到body

时,似乎firefox不会执行click事件