一、什么是JS宏?
wps宏編輯器集成了一個V8 引擎的 JAVAScript 運行時,支持大部分ES6語法,用戶可通過編寫 JS腳本來加速執行日常任務,還可以使用 JS為 WPS office添加新功能。
二、為什么要學習JS宏?
1、自動化操作。在使用WPS的過程中,經常會有重復操作的情景,這時我們可以通過編寫JS宏代碼或錄制JS宏,減少大量不必要的重復性工作,使工作自動化,提高工作效率。
2、易于掌握。JS語法簡單,學習門檻低,對于沒有編程基礎的小伙伴,也可以通過錄制宏來記錄用戶的各種操作,WPS將自動把宏轉換為JS代碼,非常容易掌握。
3、功能強大。JS宏可以調用表格自帶的函數,還可以自定義函數,文檔使用者在有工作需要時,可以通過打開宏對話框去運行宏,也可以通過結合可視化的控件,在合適的控件響應時執行宏。
三、如何在工作中實戰?
下面我們通過自動生成工資條來講解一下JS宏如何在工作中應用。
原始工資條
首先我們錄制新宏,先選中表頭,然后同時按住shift和ctrl鍵,點擊使用相對引用,按住鼠標左鍵下拉一行松開并停止錄制宏,如圖
下拉一次表頭
我們點擊宏編輯器,看到錄制的代碼
錄制的JS宏
我們通過閱讀代碼,發現其中的規律,添加一個循環,來執行剩下的操作,效果如下
最終工資條效果
修改后的代碼如下,如有不懂的地方可私信我,有問必答。
/**
* macro1 Macro
* 宏由 WPS定制 錄制,時間: 2022/10/30
*/
function Macro1()
{
Application.windowstate = xlMinimized;
Application.Left = 0;
Application.Top = 37;
Application.WindowState = xlMaximized;
Range("A2:Q3").Select();
for(var i=0;i<2;i++)
{
Selection.Copy(undefined);
ActiveCell.Offset(2, 0).Range("A1:Q2").Insert(xlShiftDown, undefined);
Application.CutCopyMode = false;
ActiveCell.Offset(2, 0).Range("A1:Q2").Select();
ActiveCell.Rows.Item("1:1").EntireRow.RowHeight = 16;
ActiveCell.Offset(1, 0).Rows.Item("1:1").EntireRow.RowHeight = 17;
}
}