使用jquery下载文件自定义名称

 所谓-旧 发布于 2023-01-06 19:53

我使用jQuery 插件将HTML表导出到Excel.使用chrome的下载文件名总是download.xls使用mozilla firefox random-string.xls.我希望根据日期创建文件名.例如23-06-2014.xls.

下面是视图文件中的自定义JS块

$(document).ready(function () {
    $("#btnExport").click(function () {
        $("#account_table").btechco_excelexport({
            containerid: "account_table", 
            datatype: $datatype.Table
        });
    });
});

Darren Kopp.. 8

您想在链接上设置downloadhref属性.例如

$("#btnExport").click(function () {
        var uri = $("#account_table").btechco_excelexport({
            containerid: "account_table", 
            datatype: $datatype.Table,
            returnUri: true
        });

        $(this).attr('download', 'ExportToExcel.xls') // set file name (you want to put formatted date here)
               .attr('href', uri)                     // data to download
               .attr('target', '_blank')              // open in new window (optional)
        ;
    });


V31.. 6

如果你不想使用这个插件,那么人们已经有了一个替代的javascript.我只是将其修改为具有文件名而不是默认名称.

var tableToExcel = (function () {
    var uri = 'data:application/vnd.ms-excel;base64,',
        template = '{table}
', base64 = function (s) { return window.btoa(unescape(encodeURIComponent(s))) }, format = function (s, c) { return s.replace(/{(\w+)}/g, function (m, p) { return c[p]; }) } return function (table, name) { if (!table.nodeType) table = document.getElementById(table) var ctx = { worksheet: name || 'Worksheet', table: table.innerHTML } var blob = new Blob([format(template, ctx)]); var blobURL = window.URL.createObjectURL(blob); return blobURL; } })()

设置名称的jquery将是:

$("#btnExport").click(function () {
    var todaysDate = moment().format('DD-MM-YYYY');
    var blobURL = tableToExcel('account_table', 'test_table');
    $(this).attr('download',todaysDate+'.xls')
    $(this).attr('href',blobURL);
});

示例: 小提琴

参考文献: Link1 Link2

2 个回答
  • 如果你不想使用这个插件,那么人们已经有了一个替代的javascript.我只是将其修改为具有文件名而不是默认名称.

    var tableToExcel = (function () {
        var uri = 'data:application/vnd.ms-excel;base64,',
            template = '<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40"><head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{worksheet}</x:Name><x:WorksheetOptions><x:DisplayGridlines/></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--><meta http-equiv="content-type" content="text/plain; charset=UTF-8"/></head><body><table>{table}</table></body></html>',
            base64 = function (s) {
                return window.btoa(unescape(encodeURIComponent(s)))
            }, 
            format = function (s, c) {
                return s.replace(/{(\w+)}/g, function (m, p) {
                    return c[p];
                })
            }
            return function (table, name) {
                if (!table.nodeType) table = document.getElementById(table)
                var ctx = {
                    worksheet: name || 'Worksheet',
                    table: table.innerHTML
                }
                var blob = new Blob([format(template, ctx)]);
                var blobURL = window.URL.createObjectURL(blob);
                return blobURL;
            }
    })()
    

    设置名称的jquery将是:

    $("#btnExport").click(function () {
        var todaysDate = moment().format('DD-MM-YYYY');
        var blobURL = tableToExcel('account_table', 'test_table');
        $(this).attr('download',todaysDate+'.xls')
        $(this).attr('href',blobURL);
    });
    

    示例: 小提琴

    参考文献: Link1 Link2

    2023-01-06 19:55 回答
  • 您想在链接上设置downloadhref属性.例如

    $("#btnExport").click(function () {
            var uri = $("#account_table").btechco_excelexport({
                containerid: "account_table", 
                datatype: $datatype.Table,
                returnUri: true
            });
    
            $(this).attr('download', 'ExportToExcel.xls') // set file name (you want to put formatted date here)
                   .attr('href', uri)                     // data to download
                   .attr('target', '_blank')              // open in new window (optional)
            ;
        });
    

    2023-01-06 19:55 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有