2016-07-18 8 views
2

私はここでstackoverflowで見つかった関数を使用しています。 Internet ExplorerとGoogle Chromeでは正常に動作しますが、FireFoxで使用すると、ダウンロードしたファイルをExcelで開くことができません。ダブルクリックするかExcelから開くと、空のワークブックが表示されます。このダウンロードしたファイルを.xlsから.htmlに変換すると、前述のブラウザで正しく開きます。FireFoxを使用してダウンロードするときに.xlsにエクスポートされたHTMLテーブルが開けません。

私が間違ってやっていることや、それを修正する方法に関するアイデアはありますか?

ありがとうございます!

function fnExcelReport(){ 
var tab_text="<table border='2px'><tr bgcolor='#87AFC6'>"; 
var textRange; var j=0; 
var tab = document.getElementById('GroupMembersTable'); // id of table 
var sa 
for(j = 0 ; j < tab.rows.length ; j++) 
{  
    tab_text=tab_text+tab.rows[j].innerHTML+"</tr>"; 
    //tab_text=tab_text+"</tr>"; 
} 

tab_text= tab_text+"</table>"; 
tab_text= tab_text.replace(/<A[^>]*>|<\/A>/g, "");//remove if u want links in your table 
tab_text= tab_text.replace(/<img[^>]*>/gi,""); // remove if u want images in your table 
tab_text= tab_text.replace(/<input[^>]*>|<\/input>/gi, ""); // removes input params 

var ua = window.navigator.userAgent; 
var msie = ua.indexOf("MSIE "); 

if (msie > 0 || !!navigator.userAgent.match(/Trident.*rv\:11\./))  // If Internet Explorer 
{ 
    txtArea1.document.open("txt/html","replace"); 
    txtArea1.document.write(tab_text); 
    txtArea1.document.close(); 
    txtArea1.focus(); 
    sa=txtArea1.document.execCommand("SaveAs",true,"SecurityAudit.xls"); 
} 
else { //other browser not tested on IE 11 
    sa = window.open('data:application/vnd.ms-excel,' + encodeURIComponent(tab_text)); 
} 
return (sa); 
} 
+0

chromeとfirefoxで作成したファイルのdiffファイルには違いがありますか? – dandavis

+0

Firefoxのダウンロード時にchromeファイルのファイル名が「ダウンロード」になり、ランダムな文字列としてダウンロードされます。どちらも拡張子が.xlsです。両方とも、HTMLに変換すると、ブラウザに同じものを表示します –

+0

https://www.diffchecker.com/diffのようなものを試してください:100%同一の場合、それらは同じように動作するはずです。 – dandavis

答えて

2

最近のWindowsセキュリティアップデートのために、同様の問題が発生しました。ダウンロードしたファイルがブロックされているとマークされています。ファイルのプロパティを表示し、[ブロックを解除]ボタンをクリックすると、ファイルがExcelで開きます。 Excelは、ワークステーションでブロックされたとマークされたファイルをもう開いていません。

0

このセキュリティ "問題"を回避し、コンピュータまたはワークステーションのインターネット(信頼ゾーン、Excelオプション)からのファイルの保護されたビューを無効にすることができます。

ファイルをダウンロードすることはできますが、ファイルを直接開くことを選択した場合は、最初に言及した無効化プロセスをメイドするまで機能しません。

関連する問題