, ben ben sadece .xls gibi o nesneyi ihraç veya file.i böyle yaklaşımların çok kullanılan .csv istiyorum, benim denetleyicisi bir nesne ettik:Açısal JS - Javascript Nesnesi XLS dosyasına nasıl dışa aktarılır? Aslında
HTML
<script src="https://rawgithub.com/eligrey/FileSaver.js/master/FileSaver.js" type="text/javascript" />
<div ng-controller="myCtrl">
<button ng-click="exportData()">Export</button>
<br />
<div id="exportable">
<table width="100%">
<thead>
<tr>
<th>Name</th>
<th>Email</th>
<th>DoB</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="item in items">
<td>{{item.name}}</td>
<td>{{item.email}}</td>
<td>{{item.dob | date:'MM/dd/yy'}}</td>
</tr>
</tbody>
</table>
</div>
</div>
JavaScript
function myCtrl($scope) {
$scope.exportData = function() {
var blob = new Blob([document.getElementById('exportable').innerHTML], {
type: "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8"
});
saveAs(blob, "Report.xls");
};
$scope.items = [{
name: "John Smith",
email: "[email protected]",
dob: "1985-10-10"
}, {
name: "Jane Smith",
email: "[email protected]",
dob: "1988-12-22"
}, {
name: "Jan Smith",
email: "[email protected]",
dob: "2010-01-02"
}, {
name: "Jake Smith",
email: "[email protected]",
dob: "2009-03-21"
}, {
name: "Josh Smith",
email: "[email protected]",
dob: "2011-12-12"
}, {
name: "Jessie Smith",
email: "[email protected]",
dob: "2004-10-12"
}]
}
ama bu değil orada sayfalara ayrılmış tables.is doğrudan (bu örnek $ scope.item olarak) nesneleri vermek için herhangi bir şekilde dosya çalışır (xls , csv)?
Bu harika bir çözüm, katkısını gerçekten takdir ediyor. Herhangi bir iç nesneyi ve koleksiyonları da ayrıştırmak için basit çözümleriniz var mı? –
Evet. SELECT'e benzer olan SEARCH işlecini deneyebilirsiniz, ancak JSON nesnesinin içinde hareket ettirebilirsiniz (bkz. Https://github.com/agershun/alasql/wiki/Search) – agershun
açmaya çalıştığınızda plunkr xlsx dosyasının bir sorunu vardır. o. – crh225