瀏覽器從Safari 10.1、Chrome 61、Firefox 60和Edge 16開始支持直接加載ECMAScript模塊(不需要Webpack等工具)。
不需要使用Node.js的擴展名;瀏覽器完全無視模塊/腳本的文件擴展名。
<script type="module">
import { hello } from './hello.js';
hello('world');
</script>
export function hello(text) {
const div=document.createElement('div');
div.textContent=`Hello ${text}`;
document.body.appendChild(div);
}
腳本根據需要動態加載其他的js文件。
<script type="module">
import('hello.js').then(module=> {
module.hello('world');
});
</script>
module.exports={
hello: function() {
return "Hello";
}
}
const myModule=require('./mymodule');
let val=myModule.hello(); // val is "Hello"
fetchInject([
'https://cdn.jsdelivr.net/momentjs/2.17.1/moment.min.js'
]).then(()=> {
console.log(`Finish in less than ${moment().endOf('year').fromNow(true)}`)
})
HTML中添加一個帶有腳本URL的腳本標簽。
腳本甚至可以在不同的服務器上(),<script>標簽注入到網頁的<head>中,或者插入到關閉的</body>標簽之前。
avaScript在前端領域占據著絕對的統治地位,目前更是從瀏覽器到服務端,移動端,嵌入式,幾乎所有的所有的應用領域都可以使用它。技術圈有一句很經典的話“凡是能用JavaScript實現的東西,最后都會用JavaScript實現”。
Excel 電子表格自 1980 年代以來一直為各行業所廣泛使用,至今已擁有超過3億用戶,大多數人都熟悉 Excel 電子表格體驗。許多企業在其業務的各個環節中使用了 Excel 電子表格進行數據管理。
作為全球領先的軟件開發技術和低代碼平臺提供商,葡萄城專注開發技術和工具已經長達四十余年,一直以來引領著國內控件技術和數據分析工具的發展。SpreadJS表格控件作為葡萄城的核心產品,能夠完美兼容 Excel 的功能和使用體驗并高度匹配在線辦公場景的需求。
SpreadJS可以為我們的Web應用提供更好的交互體驗,以及更靈活的權限控制、數據整合、數據可視化、戰略績效測量 (SPM)、復雜的統計分析等。多年來,Excel 兼容性一直是SpreadJS最重要的功能之一。
SpreadJS 提供了熟悉的 Excel 電子表格界面。用戶可以通過SpreadJS直接在頁面端導入和導出 Excel 文件——這一切無需依賴 Excel。
在本博客中,我們將介紹如何按照以下步驟在 JavaScript 中,實現頁面端電子表格導入/導出到 Excel:
1. 設置 JavaScript 電子表格項目
2. 添加 Excel 導入代碼
3. 將數據添加到導入的 Excel 文件
4. 添加迷你圖
5. 添加 Excel 導出代碼
首先,我們可以使用托管在 NPM 上的 SpreadJS 文件。為此,我們可以使用命令行參數進行安裝。打開命令提示符并導航到應用程序的位置。在那里,您可以使用一個命令安裝所需的文件。
在這種情況下,我們需要基本的 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 庫,為了便于后續程序處理,SpreadJS默認提供完整的文件流,FileSaver庫可以用來把文件流轉成文件下載到本地。
然后我們可以在頁面中添加一個腳本來初始化 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>
我們需要創建一個客戶端 ExcelIO 組件的實例,我們可以使用它來打開文件:
var excelIO=new GC.Spread.Excel.IO();
然后我們需要添加一個函數來導入文件。在此示例中,我們導入了一個本地文件,但您可以對服務器上的文件執行相同的操作。如果從服務器導入文件,您需要引用該位置。下面是一個輸入元素的示例,用戶可以在其中輸入文件的位置:
<input type="text" id="importUrl" value="http://www.testwebsite.com/files/TestExcel.xlsx" style="width:300px" />
一旦你有了它,你可以直接在腳本代碼中訪問該值:
var excelUrl=$("#importUrl").val();
導入函數的以下代碼使用“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 函數內的腳本中添加以下內容:
$(document).ready(function () {
$.support.cors=true;
workbook=new GC.Spread.Sheets.Workbook(document.getElementById("ss"));
//...
});
在這種情況下,我們需要啟用 Cross-Origin-Request-Support,因為我們可能會從 URL 加載文件。因此 $.support.cors=true;行,否則嘗試加載它會導致 CORS 錯誤。
我們使用本教程的“損益表”Excel 模板導入本地文件。
現在我們可以使用 Spread.Sheets 腳本在這個文件中添加另一個收入行。讓我們在頁面上添加一個按鈕來執行此操作:
<button id="addRevenue">Add Revenue</button>
我們可以為該按鈕的單擊事件處理程序編寫一個函數來添加一行并從前一行復制樣式以準備添加一些數據。要復制樣式,我們需要使用 copyTo 函數并傳入:
1. 原始和目標行和列索引
2. 行數和列數
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);
}
以下用于添加數據和 Sparkline 的腳本代碼將包含在此按鈕單擊事件處理程序中。對于大部分數據,我們可以使用 setValue 函數。這允許我們通過傳入行索引、列索引和值來在 Spread 中的工作表中設置值:
sheet.setValue(newRowIndex, 1, "Revenue 8");
for (var c=3; c < 15; c++) {
sheet.setValue(newRowIndex, c, Math.floor(Math.random() * 200) + 10);
}
在 P 列中設置 SUM 公式以匹配其他行并為 Q 列設置百分比:
sheet.setFormula(newRowIndex, 15, "=SUM([@[Jan]:[Dec]])")
sheet.setValue(newRowIndex, 16, 0.15);
最后,我們可以再次使用 copyTo 函數將先前行中的公式復制到 R 到 AD 列的新行,這次使用 CopyToOptions.formula:
sheet.copyTo(10, 17, newRowIndex, 17, 1, 13, GC.Spread.Sheets.CopyToOptions.formula);
現在,我們可以添加迷你圖來匹配其他數據行。為此,我們需要提供一系列單元格以從中獲取數據以及迷你圖的一些設置。在這種情況下,我們可以指定:
1. 單元格的范圍,我們只是將數據添加到
2. 使迷你圖看起來像同一列中的其他迷你圖的設置
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 方法并指定:
1. 迷你圖的位置
2. 數據的位置
3. 迷你圖的方向
4. 迷你圖的類型
5. 我們創建的設置
sheet.setSparkline(11, 2, data, GC.Spread.Sheets.Sparklines.DataOrientation.horizontal, GC.Spread.Sheets.Sparklines.SparklineType.line, setting);
如果您現在嘗試運行代碼,它可能看起來有點慢,因為每次更改數據和添加樣式時工作簿都會重新繪制。為了顯著加快速度并提高性能,Spread.Sheets 提供了暫停繪畫和計算服務的能力。讓我們在添加一行及其數據之前添加代碼以暫停兩者,然后在之后恢復兩者:
workbook.suspendPaint();
workbook.suspendCalcService();
//...
workbook.resumeCalcService();
workbook.resumePaint();
添加該代碼后,我們可以在 Web 瀏覽器中打開該頁面,并查看 Excel 文件加載到 Spread.Sheets 中并添加了收入行。重要提示:請記住,出于安全考慮,Chrome 不允許您打開本地文件,因此您需要使用 Firefox 等網絡瀏覽器才能成功運行此代碼。或者,從網站 URL 加載文件應該可以在任何瀏覽器中正常打開。
最后,我們可以添加一個按鈕來導出包含添加行的文件。為此,我們可以使用 Spread.Sheets 中內置的客戶端 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" />
然后我們可以添加一個按鈕來調用這個函數:
<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 中打開它,并查看文件與導入時的外觀相同,只是現在我們添加了額外的收入行。
這只是一個示例,說明如何使用 SpreadJS JavaScript 電子表格將數據添加到 Excel 文件,然后使用簡單的 JavaScript 代碼將它們導出回 Excel。
時候,我們會碰到這樣一種情況:我們的wordpress網站主題模板已經定型了,但是,我們后期又想向wordpress網站添加一些新功能,這時候,我們該怎么辦?是繼續修改wordpress網站主題模板嗎?當然,修改主題模板肯定可以。但是時間久了,對當前的主題模板可能會有些生疏,修改起來可能會有點吃力。還有沒有其它方式向wordpress網站添加新功能?當然是有的了。在部分功能應用上,我們可以使用wp_head()這個函數 + 插件的形式來完成一些功能。下面一起來看看wp_head()函數是如何來將插件數據插件前臺頁面的。
進入到wordpress網站的插件目錄/wp-content/plugins/,在這個插件目錄下創建一個app目錄,也就是要創建一個名為app的插件。如下圖:
然后,在這個app插件目錄下創建2個文件,一個bbb.css文件和index.php文件,如下圖:
這里的bbb.css文件是這個插件的樣式文件,index.php是這個app插件的主頁文件。我們這里要實現的功能,只是一個演示功能,就是要修改前臺頁面字體的大小和顏色。
index.php文件代碼如下:
<?php/*plugin name: app //這個是必須的,否則后臺插件列表中就找不到這個插件plugin uri: http://wanlimm.comauthor: 馬不停蹄version: 1.0description: 這是一個使用wp-head()函數的插件*/function my_head(){ //向wordpress網站頭部添加一個樣式文件echo '<link rel="stylesheet" href="'.WP_PLUGIN_URL.'/app/bbb.css">';}if(!is_admin()){ //如果不是后臺,就把my_head函數添加到wordpress的動作勾子wp_head勾子里。add_action("wp_head","my_head");}
bbb.css文件的代碼如下:
body{color:red; font-size:40px;}
把wordpress網站前臺頁面的文字顏色變成紅色,字體大小變成40像素。
通過第一步的添加后,我們就可以在wordpress網站的后臺插件列表中看到這個app插件了,如下圖:
我們點擊“啟用”按鈕,啟用這個app插件。插件只有被啟用了,它的功能才會被應用到wordpress網站的前臺頁面當中去。當然,雖然我們現在啟用了,我們wordpress網站的前臺的文字字體依然沒有變化。如下圖(我們上節課添加的內容)。
通過上面兩步,我們已經準備好了功能,就等著我們的wordpress網站前臺調用呢。這時,我們需要使用到wp_head()這個頭部函數,這個頭部函數的功能還是非常強大的,它可以把我們向wordpress的wp_head勾子里添加的所有動作函數添加到wordpress網站的前臺頁面中。不過,這個wp_head()函數必須添加在wordpress網站前臺頁面的< head>標簽之內才有效,如下圖:
這時,我們看一下wordpress網站的前臺頁面,看看頁面字體有沒有變化。這時,字體變大了,也變成了紅色。如下圖:
之所以旁邊的“返回首頁”是藍色,因為它是鏈接,想要修改它的顏色,必須單獨為它設置顏色。我們再來看一下源代碼,如下圖,wp_head()函數在wordpress網站的前臺的< head>標簽中插入了我們創建的插件app的樣式文件bbb.css。
?當然,wp_head()函數在插件bbb.css樣式文件的同時,會向< head>標簽插入很多其它的代碼,有些代碼對我們根本沒什么用處,我們是可以通過一些手段來處理掉了,這個在我們后期的文章中會有相關的介紹。
好了,到這里,本節就接近尾聲。本節課的目的,主要是介紹“如何通過wp_head()函數向wordpress網站的前臺頁面的頭部添加數據代碼”,這個應用非常廣泛,很多wordpress插件都要使用到wp_head()這個函數,如果不使用這個函數,這些插件就無法使用。
以上就是我的觀點,如有不同觀點,歡迎發表評論。同時,歡迎【點贊、分享、收藏】和【關注】我。
*請認真填寫需求信息,我們會在24小時內與您取得聯系。