欧美成人精品手机在线观看_69视频国产_动漫精品第一页_日韩中文字幕网 - 日本欧美一区二区

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

前端必讀:如何在 JavaScript 中使用SpreadJS導(dǎo)入和導(dǎo)出 Excel 文件

admin
2023年5月25日 10:43 本文熱度 798

Javascript在前端領(lǐng)域占據(jù)著絕對(duì)的統(tǒng)治地位,目前更是從瀏覽器到服務(wù)端,移動(dòng)端,嵌入式,幾乎所有的所有的應(yīng)用領(lǐng)域都可以使用它。技術(shù)圈有一句很經(jīng)典的話“凡是能用Javascript實(shí)現(xiàn)的東西,最后都會(huì)用Javascript實(shí)現(xiàn)”。

Excel 電子表格自 1980 年代以來一直為各行業(yè)所廣泛使用,至今已擁有超過3億用戶,大多數(shù)人都熟悉 Excel 電子表格體驗(yàn)。許多企業(yè)在其業(yè)務(wù)的各個(gè)環(huán)節(jié)中使用了 Excel 電子表格進(jìn)行數(shù)據(jù)管理。

在本文中,我們將介紹如何按照以下步驟在 Javascript 中,實(shí)現(xiàn)頁面端電子表格導(dǎo)入/導(dǎo)出到 Excel:

完整Demo示例請(qǐng)點(diǎn)擊此處下載如何使用Javascript導(dǎo)入和導(dǎo)出Excel文件Demo.zip

1、設(shè)置 Javascript 電子表格項(xiàng)目

2、添加 Excel 導(dǎo)入代碼

3、將數(shù)據(jù)添加到導(dǎo)入的 Excel 文件

4、添加迷你圖

5、添加 Excel 導(dǎo)出代碼


1、設(shè)置 Javascript 電子表格項(xiàng)目

首先,我們可以使用托管在 NPM 上的 SpreadJS 文件。為此,我們可以使用命令行參數(shù)進(jìn)行安裝。打開命令提示符并導(dǎo)航到應(yīng)用程序的位置。在那里,您可以使用一個(gè)命令安裝所需的文件。


在這種情況下,我們需要基本的 Spread-Sheets 庫、Spread-ExcelIO 和 jQuery:

npm i @grapecity/spread-sheets @grapecity/spread-excelio jquery


SpreadJS 不依賴于 jQuery,但在這種情況下,我們使用它來提供簡單的跨域請(qǐng)求支持,稍后我們將對(duì)其進(jìn)行回顧。


一旦安裝了這些,我們就可以在我們的代碼中添加對(duì)這些腳本和 CSS 文件的引用:

<!DOCTYPE html>  

<html>  

<head>  

    <title>SpreadJS ExcelIO</title>

    <script src="./node_modules/jquery/dist/jquery.min.js" type="text/javascript"></script>

    <script src="https://cdnjs.cloudflare.com/ajax/libs/FileSaver.js/2014-11-29/FileSaver.min.js"></script>

    <link href="./node_modules/@grapecity/spread-sheets/styles/gc.spread.sheets.excel2013white.css" rel="stylesheet" type="text/css" />

    <script type="text/javascript" src="./node_modules/@grapecity/spread-sheets/dist/gc.spread.sheets.all.min.js"></script>

    <script type="text/javascript" src="./node_modules/@grapecity/spread-excelio/dist/gc.spread.excelio.min.js"></script>

</head>  

<body>  

    <div id="ss" style="height:600px; width :100%; "></div>  

</body>  

</html>  


除了 SpreadJS 和 jQuery 文件之外,我們還需要導(dǎo)入 FileSaver 庫,為了便于后續(xù)程序處理,SpreadJS默認(rèn)提供完整的文件流,F(xiàn)ileSaver庫可以用來把文件流轉(zhuǎn)成文件下載到本地。


然后我們可以在頁面中添加一個(gè)腳本來初始化 Spread.Sheets 組件和一個(gè) div 元素來包含它(因?yàn)?SpreadJS 電子表格組件使用了一個(gè)畫布,這是初始化組件所必需的):

<script type="text/javascript">  

        $(document).ready(function () {  

            var workbook = new GC.Spread.Sheets.Workbook(document.getElementById("ss"));  

        });  

</script>  

</head>  

<body>  

    <div id="ss" style="height:600px ; width :100%; "></div>  

</body>


2、添加 Excel 導(dǎo)入代碼

我們需要?jiǎng)?chuàng)建一個(gè)客戶端 ExcelIO 組件的實(shí)例,我們可以使用它來打開文件:

var excelIO = new GC.Spread.Excel.IO();


然后我們需要添加一個(gè)函數(shù)來導(dǎo)入文件。在此示例中,我們導(dǎo)入了一個(gè)本地文件,但您可以對(duì)服務(wù)器上的文件執(zhí)行相同的操作。如果從服務(wù)器導(dǎo)入文件,您需要引用該位置。下面是一個(gè)輸入元素的示例,用戶可以在其中輸入文件的位置:

<input type="text" id="importUrl" value="http://www.testwebsite.com/files/TestExcel.xlsx" style="width:300px" />


一旦你有了它,你可以直接在腳本代碼中訪問該值:

var excelUrl = $("#importUrl").val();


導(dǎo)入函數(shù)的以下代碼使用“excelUrl”變量的本地文件:

function ImportFile() {  

    var excelUrl = "./test.xlsx";  

    var oReq = new XMLHttpRequest();  

    oReq.open('get', excelUrl, true);  

    oReq.responseType = 'blob';  

    oReq.onload = function () {  

        var blob = oReq.response;  

        excelIO.open(blob, LoadSpread, function (message) {  

            console.log(message);  

        });  

    };  

    oReq.send(null);  

}  

function LoadSpread(json) {  

    jsonData = json;  

    workbook.fromJSON(json);  

    workbook.setActiveSheet("Revenues (Sales)");  

}  


無論您是在服務(wù)器上還是在本地引用文件,都需要在 $(document).ready 函數(shù)內(nèi)的腳本中添加以下內(nèi)容:

$(document).ready(function () {  

    $.support.cors = true;  

    workbook = new GC.Spread.Sheets.Workbook(document.getElementById("ss"));  

    //...  

});  


在這種情況下,我們需要啟用 Cross-Origin-Request-Support,因?yàn)槲覀兛赡軙?huì)從 URL 加載文件。因此 $.support.cors = true;行,否則嘗試加載它會(huì)導(dǎo)致 CORS 錯(cuò)誤。


3、將數(shù)據(jù)添加到導(dǎo)入的 Excel 文件

我們使用本教程的“損益表”Excel 模板導(dǎo)入本地文件。

 

現(xiàn)在我們可以使用 Spread.Sheets 腳本在這個(gè)文件中添加另一個(gè)收入行。讓我們?cè)陧撁嫔咸砑右粋€(gè)按鈕來執(zhí)行此操作:

Add Revenue


我們可以為該按鈕的單擊事件處理程序編寫一個(gè)函數(shù)來添加一行并從前一行復(fù)制樣式以準(zhǔn)備添加一些數(shù)據(jù)。要復(fù)制樣式,我們需要使用 copyTo 函數(shù)并傳入:

1、原始和目標(biāo)行和列索引

2、行數(shù)和列數(shù)

3、樣式的 CopyToOptions 值

document.getElementById("addRevenue").onclick = function () {  

    var sheet = workbook.getActiveSheet();  

    sheet.addRows(newRowIndex, 1);  

    sheet.copyTo(10, 1, newRowIndex, 1, 1, 29, GC.Spread.Sheets.CopyToOptions.style);  

}


以下用于添加數(shù)據(jù)和 Sparkline 的腳本代碼將包含在此按鈕單擊事件處理程序中。對(duì)于大部分?jǐn)?shù)據(jù),我們可以使用 setValue 函數(shù)。這允許我們通過傳入行索引、列索引和值來在 Spread 中的工作表中設(shè)置值:

sheet.setValue(newRowIndex, 1, "Revenue 8");  

for (var c = 3; c < 15; c++) {  

    sheet.setValue(newRowIndex, c, Math.floor(Math.random() * 200) + 10);  

}  


最后,我們可以再次使用 copyTo 函數(shù)將先前行中的公式復(fù)制到 R 到 AD 列的新行,這次使用 CopyToOptions.formula:

sheet.copyTo(10, 17, newRowIndex, 17, 1, 13, GC.Spread.Sheets.CopyToOptions.formula);  


4、添加迷你圖

現(xiàn)在,我們可以添加迷你圖來匹配其他數(shù)據(jù)行。為此,我們需要提供一系列單元格以從中獲取數(shù)據(jù)以及迷你圖的一些設(shè)置。在這種情況下,我們可以指定:

1、單元格的范圍,我們只是將數(shù)據(jù)添加到

2、使迷你圖看起來像同一列中的其他迷你圖的設(shè)置

var data = new GC.Spread.Sheets.Range(11, 3, 1, 12);  

var setting = new GC.Spread.Sheets.Sparklines.SparklineSetting();  

setting.options.seriesColor = "Text 2";  

setting.options.lineWeight = 1;  

setting.options.showLow = true;  

setting.options.showHigh = true;  

setting.options.lowMarkerColor = "Text 2";  

setting.options.highMarkerColor = "Text 1";  


之后,我們調(diào)用 setSparkline 方法并指定:

1、迷你圖的位置

2、數(shù)據(jù)的位置

3、迷你圖的方向

4、迷你圖的類型

5、我們創(chuàng)建的設(shè)置

sheet.setSparkline(11, 2, data, GC.Spread.Sheets.Sparklines.DataOrientation.horizontal, GC.Spread.Sheets.Sparklines.SparklineType.line, setting);  


如果您現(xiàn)在嘗試運(yùn)行代碼,它可能看起來有點(diǎn)慢,因?yàn)槊看胃臄?shù)據(jù)和添加樣式時(shí)工作簿都會(huì)重新繪制。為了顯著加快速度并提高性埽琒pread.Sheets 提供了暫停繪畫和計(jì)算服務(wù)的能力。讓我們?cè)谔砑右恍屑捌鋽?shù)據(jù)之前添加代碼以暫停兩者,然后在之后恢復(fù)兩者:

workbook.suspendPaint();  

workbook.suspendCalcService();  

//...  

workbook.resumeCalcService();  

workbook.resumePaint();  


添加該代碼后,我們可以在 Web 瀏覽器中打開該頁面,并查看 Excel 文件加載到 Spread.Sheets 中并添加了收入行。重要提示:請(qǐng)記住,出于安全考慮,Chrome 不允許您打開本地文件,因此您需要使用 Firefox 等網(wǎng)絡(luò)瀏覽器才能成功運(yùn)行此代碼。或者,從網(wǎng)站 URL 加載文件應(yīng)該可以在任何瀏覽器中正常打開。


5、添加 Excel 導(dǎo)出代碼

最后,我們可以添加一個(gè)按鈕來導(dǎo)出包含添加行的文件。為此,我們可以使用 Spread.Sheets 中內(nèi)置的客戶端 ExcelIO 代碼:

function ExportFile() {  

    var fileName = $("#exportFileName").val();  

    if (fileName.substr(-5, 5) !== '.xlsx') {  

        fileName += '.xlsx';  

    }  

    var json = JSON.stringify(workbook.toJSON());  

    excelIO.save(json, function (blob) {  

        saveAs(blob, fileName);  

    }, function (e) {  

        if (e.errorCode === 1) {  

            alert(e.errorMessage);  

        }  

    });  

}  


該代碼從 exportFileName 輸入元素獲取導(dǎo)出文件名。我們可以定義它并讓用戶像這樣命名文件:

<input type="text" id="exportFileName" placeholder="Export file name" value="export.xlsx" />  


然后我們可以添加一個(gè)按鈕來調(diào)用這個(gè)函數(shù):

<button id="export">Export File</button>  

document.getElementById("export").onclick = function () {  

    ExportFile();  


添加收入行后,您可以使用“導(dǎo)出文件”按鈕導(dǎo)出文件。確保添加 FileSaver 外部庫以允許用戶將文件保存在他們想要的位置:

<script src="https://cdnjs.cloudflare.com/ajax/libs/FileSaver.js/2014-11-29/FileSaver.min.js"></script>  


成功導(dǎo)出文件后,您可以在 Excel 中打開它,并查看文件與導(dǎo)入時(shí)的外觀相同,只是現(xiàn)在我們添加了額外的收入行。

 

這只是一個(gè)示例,說明如何使用 SpreadJS Javascript 電子表格將數(shù)據(jù)添加到 Excel 文件,然后使用簡單的 Javascript 代碼將它們導(dǎo)出回 Excel。


在另一個(gè)系列文章中,我們演示了如何在其他 Javascript 框架中導(dǎo)入/導(dǎo)出 Excel 電子表格:

  • React

  • Vue

  • Angular


本文示例下載地址:

https://gcdn.grapecity.com.cn/forum.php?mod=attachment&aid=MjMzMzU3fGU0NTJlZWEyfDE2NjM3MjYyNTl8NjI2NzZ8OTk3MTg%3D


更多純前端表格在線demo示例:https://demo.grapecity.com.cn/spreadjs/gc-sjs-samples/index.html

純前端表格應(yīng)用場景:https://www.grapecity.com.cn/developer/spreadjs#scenarios

移動(dòng)端示例(可掃碼體驗(yàn)):http://demo.grapecity.com.cn/spreadjs/mobilesample/

————————————————

版權(quán)聲明:本文為CSDN博主「葡萄城技術(shù)團(tuán)隊(duì)」的原創(chuàng)文章,遵循CC 4.0 BY-SA版權(quán)協(xié)議,轉(zhuǎn)載請(qǐng)附上原文出處鏈接及本聲明。

原文鏈接:https://blog.csdn.net/powertoolsteam/article/details/126969155


該文章在 2023/5/25 10:44:20 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲(chǔ)管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved