111 lines
3.4 KiB
HTML
111 lines
3.4 KiB
HTML
|
<!DOCTYPE html>
|
||
|
<!-- xlsx.js (C) 2013-present SheetJS http://sheetjs.com -->
|
||
|
<!-- vim: set ts=2: -->
|
||
|
<html ng-app="sjs">
|
||
|
<head>
|
||
|
<title>SheetJS + KnockoutJS</title>
|
||
|
<!-- KnockoutJS -->
|
||
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.4.2/knockout-min.js"></script>
|
||
|
|
||
|
<!-- SheetJS js-xlsx library -->
|
||
|
<script src="shim.js"></script>
|
||
|
<script src="xlsx.full.min.js"></script>
|
||
|
</head>
|
||
|
<body>
|
||
|
<pre>
|
||
|
<b><a href="https://sheetjs.com">SheetJS + KnockoutJS demo</a></b>
|
||
|
|
||
|
The core library can be used as-is in KnockoutJS applications.
|
||
|
The <a href="https://github.com/sheetjs/js-xlsx">Community Edition README</a> details some common use cases.
|
||
|
We also have some <a href="http://sheetjs.com/demos/">more public demos</a>
|
||
|
|
||
|
This demo shows:
|
||
|
- view model backed by an array of arrays
|
||
|
- file import that refreshes the model
|
||
|
- table of editable `input` elements that are bound to the model
|
||
|
- file export based on the model
|
||
|
|
||
|
<a href="https://sheetjs.com/pres.xlsx">Sample Spreadsheet</a>
|
||
|
</pre>
|
||
|
|
||
|
<input name="xlfile" id="xlf" class="left" style="width: 200px;" type="file">
|
||
|
<table data-bind="foreach: aoa">
|
||
|
<tr data-bind="foreach: $data">
|
||
|
<td><input data-bind="value: $parent[$index()]"/></td>
|
||
|
</tr>
|
||
|
</table>
|
||
|
<script id='aoa' type="text/html"></script>
|
||
|
<button id="export">Export Sheet to XLSX</button>
|
||
|
|
||
|
</div>
|
||
|
|
||
|
<script>
|
||
|
/* knockout setup */
|
||
|
var ViewModel = function() {
|
||
|
/* use an array of arrays */
|
||
|
this.aoa = ko.observableArray([
|
||
|
[1,2],
|
||
|
[3,4]
|
||
|
]);
|
||
|
};
|
||
|
|
||
|
var model = new ViewModel();
|
||
|
ko.applyBindings(model);
|
||
|
/* do an update to confirm KO was loaded properly */
|
||
|
model.aoa([[1,2,3],[4,5,6]]);
|
||
|
model.aoa.push([7,8,9]);
|
||
|
|
||
|
/* set up file input handler */
|
||
|
(function() {
|
||
|
var input_dom_element = document.getElementById('xlf');
|
||
|
var rABS = true; // true: readAsBinaryString ; false: readAsArrayBuffer
|
||
|
function handleFile(e) {
|
||
|
var files = e.target.files, f = files[0];
|
||
|
var reader = new FileReader();
|
||
|
reader.onload = function(e) {
|
||
|
var data = e.target.result;
|
||
|
if(!rABS) data = new Uint8Array(data);
|
||
|
var workbook = XLSX.read(data, {type: rABS ? 'binary' : 'array'});
|
||
|
process_wb(workbook);
|
||
|
};
|
||
|
if(rABS) reader.readAsBinaryString(f); else reader.readAsArrayBuffer(f);
|
||
|
}
|
||
|
input_dom_element.addEventListener('change', handleFile, false);
|
||
|
})();
|
||
|
|
||
|
/* update model */
|
||
|
function process_wb(wb) {
|
||
|
/* pull first worksheet */
|
||
|
var ws = wb.Sheets[wb.SheetNames[0]];
|
||
|
/* convert to AOA */
|
||
|
var aoa = XLSX.utils.sheet_to_json(ws, {header:1});
|
||
|
/* update model */
|
||
|
model.aoa(aoa);
|
||
|
}
|
||
|
|
||
|
document.getElementById("export").onclick = function() {
|
||
|
/* get array of arrays */
|
||
|
var data = model.aoa();
|
||
|
/* convert to worksheet */
|
||
|
var ws = XLSX.utils.aoa_to_sheet(data);
|
||
|
/* build new workbook */
|
||
|
var wb = XLSX.utils.book_new(); XLSX.utils.book_append_sheet(wb, ws, "Sheet1");
|
||
|
/* write file */
|
||
|
XLSX.writeFile(wb, "knockout.xlsx")
|
||
|
};
|
||
|
</script>
|
||
|
<script type="text/javascript">
|
||
|
/* eslint no-use-before-define:0 */
|
||
|
var _gaq = _gaq || [];
|
||
|
_gaq.push(['_setAccount', 'UA-36810333-1']);
|
||
|
_gaq.push(['_trackPageview']);
|
||
|
|
||
|
(function() {
|
||
|
var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
|
||
|
ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
|
||
|
var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
|
||
|
})();
|
||
|
</script>
|
||
|
</body>
|
||
|
</html>
|