亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript?中使用SpreadJS導入和導出?Excel?文件的方法

 更新時間:2022年09月22日 08:57:49   作者:葡萄城技術團隊  
這篇文章主要介紹了如何在?JavaScript?中使用SpreadJS導入和導出?Excel?文件,本文通過圖文實例代碼相結合給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

JavaScript在前端領域占據(jù)著絕對的統(tǒng)治地位,目前更是從瀏覽器到服務端,移動端,嵌入式,幾乎所有的所有的應用領域都可以使用它。技術圈有一句很經(jīng)典的話“凡是能用JavaScript實現(xiàn)的東西,最后都會用JavaScript實現(xiàn)”。
Excel 電子表格自 1980 年代以來一直為各行業(yè)所廣泛使用,至今已擁有超過3億用戶,大多數(shù)人都熟悉 Excel 電子表格體驗。許多企業(yè)在其業(yè)務的各個環(huán)節(jié)中使用了 Excel 電子表格進行數(shù)據(jù)管理。

在本博客中,我們將介紹如何按照以下步驟在 JavaScript 中,實現(xiàn)頁面端電子表格導入/導出到 Excel:
完整Demo示例請點擊此處下載。

  • 設置 JavaScript 電子表格項目
  • 添加 Excel 導入代碼
  • 將數(shù)據(jù)添加到導入的 Excel 文件
  • 添加迷你圖
  • 添加 Excel 導出代碼

設置 JavaScript 電子表格項目

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

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

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

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

一旦安裝了這些,我們就可以在我們的代碼中添加對這些腳本和 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 文件之外,我們還需要導入 FileSaver 庫,為了便于后續(xù)程序處理,SpreadJS默認提供完整的文件流,F(xiàn)ileSaver庫可以用來把文件流轉成文件下載到本地。

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

 <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>

添加 Excel 導入代碼

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

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

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

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

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

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

導入函數(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)");  
}  

無論您是在服務器上還是在本地引用文件,都需要在 $(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,因為我們可能會從 URL 加載文件。因此 $.support.cors = true;行,否則嘗試加載它會導致 CORS 錯誤。

將數(shù)據(jù)添加到導入的 Excel 文件

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

現(xiàn)在我們可以使用 Spread.Sheets 腳本在這個文件中添加另一個收入行。讓我們在頁面上添加一個按鈕來執(zhí)行此操作:
Add Revenue

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

  • 原始和目標行和列索引
  • 行數(shù)和列數(shù)
  • 樣式的 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 的腳本代碼將包含在此按鈕單擊事件處理程序中。對于大部分數(shù)據(jù),我們可以使用 setValue 函數(shù)。這允許我們通過傳入行索引、列索引和值來在 Spread 中的工作表中設置值:

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ù)將先前行中的公式復制到 R 到 AD 列的新行,這次使用 CopyToOptions.formula:

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

添加迷你圖

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

  • 單元格的范圍,我們只是將數(shù)據(jù)添加到
  • 使迷你圖看起來像同一列中的其他迷你圖的設置
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";  

之后,我們調用 setSparkline 方法并指定:

  • 迷你圖的位置
  • 數(shù)據(jù)的位置
  • 迷你圖的方向
  • 迷你圖的類型
  • 我們創(chuàng)建的設置
sheet.setSparkline(11, 2, data, GC.Spread.Sheets.Sparklines.DataOrientation.horizontal, GC.Spread.Sheets.Sparklines.SparklineType.line, setting);  

如果您現(xiàn)在嘗試運行代碼,它可能看起來有點慢,因為每次更改數(shù)據(jù)和添加樣式時工作簿都會重新繪制。為了顯著加快速度并提高性能,Spread.Sheets 提供了暫停繪畫和計算服務的能力。讓我們在添加一行及其數(shù)據(jù)之前添加代碼以暫停兩者,然后在之后恢復兩者:

workbook.suspendPaint();  
workbook.suspendCalcService();  
//...  
workbook.resumeCalcService();  
workbook.resumePaint();  

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

添加 Excel 導出代碼

最后,我們可以添加一個按鈕來導出包含添加行的文件。為此,我們可以使用 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 輸入元素獲取導出文件名。我們可以定義它并讓用戶像這樣命名文件:

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

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

<button id="export">Export File</button>  
document.getElementById("export").onclick = function () {  
    ExportFile();  
}  

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

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

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

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

在另一個系列文章中,我們演示了如何在其他 Javascript 框架中導入/導出 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 
純前端表格應用場景:https://www.grapecity.com.cn/developer/spreadjs#scenarios
移動端示例(可掃碼體驗):http://demo.grapecity.com.cn/spreadjs/mobilesample/

到此這篇關于如何在 JavaScript 中使用SpreadJS導入和導出 Excel 文件的文章就介紹到這了,更多相關js使用SpreadJS導入和導出 Excel內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 利用JS自動打開頁面上鏈接的實現(xiàn)代碼

    利用JS自動打開頁面上鏈接的實現(xiàn)代碼

    今天經(jīng)過測試,實現(xiàn)了利用JS來自動打開頁面上的鏈接的功能,其實比較簡單,就是在頁面上把鏈接列表列出來,然后通過JQuery的相關控制,在框架頁中把鏈接打開,具體能做什么用,大家自己想,哈哈。
    2011-09-09
  • 微信小程序實現(xiàn)長按刪除圖片的示例

    微信小程序實現(xiàn)長按刪除圖片的示例

    本篇文章主要介紹了微信小程序實現(xiàn)長按刪除圖片的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • JS判斷當前是否平板安卓并是否支持cordova方法的示例代碼

    JS判斷當前是否平板安卓并是否支持cordova方法的示例代碼

    這篇文章主要介紹了JS判斷當前是否平板安卓并是否支持cordova方法,pc和安卓平板共用一套代碼,平板的代碼用了cordova做了一個殼子嵌套如果用了cordova就不支持elementUI中的上傳功能,本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • JavaScript基于ajax編輯信息用法實例

    JavaScript基于ajax編輯信息用法實例

    這篇文章主要介紹了JavaScript基于ajax編輯信息用法,涉及javascript基于Ajax操作鼠標事件及實時保存文本的相關技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-07-07
  • 基于Leaflet的Webgis經(jīng)緯網(wǎng)格功能實現(xiàn)

    基于Leaflet的Webgis經(jīng)緯網(wǎng)格功能實現(xiàn)

    本文將介紹一款Leaflet的經(jīng)緯網(wǎng)插件,基于這款經(jīng)緯網(wǎng)插件,詳細介紹如何實現(xiàn)經(jīng)緯網(wǎng)功能,本文通過實例代碼給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧
    2023-12-12
  • 微信小程序用戶授權最佳實踐指南

    微信小程序用戶授權最佳實踐指南

    這篇文章主要給大家介紹了關于微信小程序用戶授權最佳實踐的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-05-05
  • JS實現(xiàn)兩表格里數(shù)據(jù)來回轉移的方法

    JS實現(xiàn)兩表格里數(shù)據(jù)來回轉移的方法

    這篇文章主要介紹了JS實現(xiàn)兩表格里數(shù)據(jù)來回轉移的方法,涉及javascript鼠標事件及頁面元素的相關操作技巧,需要的朋友可以參考下
    2015-05-05
  • JS+HTML5 Canvas實現(xiàn)簡單的寫字板功能示例

    JS+HTML5 Canvas實現(xiàn)簡單的寫字板功能示例

    這篇文章主要介紹了JS+HTML5 Canvas實現(xiàn)簡單的寫字板功能,結合實例形式分析了js結合HTML5 canvas特性的圖形繪制相關操作技巧,需要的朋友可以參考下
    2018-08-08
  • js+flash實現(xiàn)的5圖變換效果廣告代碼(附演示與demo源碼下載)

    js+flash實現(xiàn)的5圖變換效果廣告代碼(附演示與demo源碼下載)

    這篇文章主要介紹了js+flash實現(xiàn)的5圖變換效果廣告代碼,涉及JavaScript結合flash調用圖片實現(xiàn)幻燈廣告效果,并附帶演示與demo源碼供讀者下載參考,需要的朋友可以參考下
    2016-04-04
  • JS獲取鼠標選中的文字

    JS獲取鼠標選中的文字

    下面是小編給大家分享的js獲取鼠標選中的文字和js獲取鼠標選中的值關鍵代碼,大家如果有需要可以參考下
    2016-08-08

最新評論