2013-07-15 2 views
0

У меня возникла проблема с тем, что с помощью фрагмента кода, который я получил откуда-то в Интернете, я могу отлично создать xls. файл из моей таблицы html (созданный с помощью mysql/php), но он не отображает все результаты. Он захватывает только строки, которые он видит на лицевой стороне. Но я использую разбивку на страницы, и в фоновом режиме есть другие результаты. Как настроить код, чтобы он также захватывал информацию с других страниц.Экспорт html с jquery, включая разбиение на страницы

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]--></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 
     } 
     window.location.href = uri + base64(format(template, ctx)) 
    } 
})() 

ответ

0

ЗАКАНЧИВАТЬ DataTables плагин или JQuery. Он обрабатывает разбиение на страницы, экспорт в excel, плюс кучи других интересных вещей, которые вы можете делать с таблицами данных.

Это спасет вас, если у вас сложная функция JS, подобная той, которую вы разместили выше.

+0

Да, спасибо. Я уже это сделал. Но когда я вставляю функцию , я всегда получаю сообщение об ошибке: Предупреждение DataTables (таблица id = 'a1'): Не удается повторно инициализировать DataTable. Чтобы получить объект DataTables для этой таблицы, не передавайте аргументы или не смотрите документы для bRetrieve и bDestro –

+0

Я бы создал новый вопрос об этом, вместо того, чтобы пытаться его устранить. Обязательно включите HTML-таблицу и точный javascript, который вы используете, вместе с ошибкой. Я думаю, что будет реальная выгода от использования DataTables для вас вместо того, чтобы пытаться получить биты и куски скриптов, работающих со всей сети. –

+0

Хотя Google, похоже, говорит, что ошибка, вероятно, связана с тем, что вы запускаете javascript до того, как таблица была загружена на страницу. Попробуйте использовать сценарий под таблицей и посмотрите, не изменилось ли это :-) –