El siguiente método funciona en IE11 +, Firefox 25+ y Chrome 30+:
<a id="export" class="myButton" download="" href="#">export</a>
<script>
function createDownloadLink(anchorSelector, str, fileName){
if(window.navigator.msSaveOrOpenBlob) {
var fileData = [str];
blobObject = new Blob(fileData);
$(anchorSelector).click(function(){
window.navigator.msSaveOrOpenBlob(blobObject, fileName);
});
} else {
var url = "data:text/plain;charset=utf-8," + encodeURIComponent(str);
$(anchorSelector).attr("download", fileName);
$(anchorSelector).attr("href", url);
}
}
$(function () {
var str = "hi,file";
createDownloadLink("#export",str,"file.txt");
});
</script>
Vea esto en acción: http://jsfiddle.net/Kg7eA/
Firefox y Chrome admiten URI de datos para la navegación, lo que nos permite crear archivos navegando a un URI de datos, mientras que IE no lo admite por motivos de seguridad.
Por otro lado, IE tiene una API para guardar un blob, que se puede usar para crear y descargar archivos.