亚洲熟妇av一区二区三区,久久久久久精品观看sss,免费观看四虎精品国产永久,国产成人精品一区二三区熟女,天堂网在线最新版www资源网

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

表單&函數(shù)

闊別多日, SpreadJS 新人學(xué)習(xí)筆記,本周起正式回歸!

(在斷更的這一個月中,我為大家先后錄制了14期 SpreadJS 產(chǎn)品入門系列學(xué)習(xí)視頻,希望幫助那些正在學(xué)習(xí)和使用 SpreadJS 的同學(xué)全面、快速地了解產(chǎn)品,并盡快在實際項目中感受到 SpreadJS 強大的前端表格功能!這些視頻目前已經(jīng)在 GCDN 技術(shù)論壇中發(fā)布,歡迎大家觀看學(xué)習(xí),并提出意見和建議。)

本周,我會詳細介紹 SpreadJS 的表單及函數(shù),希望我的學(xué)習(xí)筆記能夠幫助你們,從零開始學(xué)習(xí) SpreadJS,并逐步精通。


本周學(xué)習(xí)計劃一:SpreadJS 的表單

初始化 SpreadJS 表單

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

你可以在 SpreadJS 中添加一個或多個表單。如圖所示,點擊按鈕,即可新增、刪除、清空表單:

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

SpreadJS 邊框網(wǎng)格線

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

SpreadJS 可自定義是否顯示網(wǎng)格線,并允許設(shè)置各種邊框的樣式。

隱藏與顯示

SpreadJS 用于控制隱藏顯示的代碼為:sheet.visible(false)

點擊【隱藏】【顯示】按鈕可依次隱藏、顯示表單。

縮放

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

SpreadJS 通過以下方法控制縮放:sheet.zoom(number),number 的值在0-1之間會縮小,1以上會放大。

行頭與列頭

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

SpreadJS 可以對行頭、列頭的樣式進行自定義,比如增加行頭、合并行頭單元格、設(shè)置寬度等,還可控制是否顯示行頭列頭,并將行標列表設(shè)定為空、數(shù)字或字母。

合并單元格

sheet.addSpan() 方法可以實現(xiàn)合并單元格:

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

SpreadJS 允許用戶通過拖拽的方式合并單元格:

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

凍結(jié)行列

SpreadJS 可以控制凍結(jié)行列,上圖中的紅線為凍結(jié)線,凍結(jié)線顏色、樣式均可自定義,如將凍結(jié)線的顏色設(shè)置為紅色:sheet.options.frozenlineColor = \’red\’

獲取與設(shè)置數(shù)據(jù)

SpreadJS 用于操作數(shù)據(jù)的方法包含:setText、getText、copyTo、moveTo、clear 五種。

舉例:

// 如將行索引5、列索引4的內(nèi)容,復(fù)制到行索引6、列索引5,并復(fù)制2行1列,可以設(shè)置如下參數(shù)

sheet.copyTo(5, 4, 6, 5, 2, 1, spreadNS.CopyToOptions.all);

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

設(shè)置公式

SpreadJS支持在單元格中設(shè)置公式,如下圖實現(xiàn)的簡單加法公式:

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

設(shè)置字體

SpreadJS 提供字體設(shè)置,允許用戶設(shè)置字體風格、大小、斜體等:

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

設(shè)置樣式

SpreadJS 可以自定義單元格樣式,如背景色、字體顏色、內(nèi)容排列方向等。此外,還可以設(shè)定一套常用的樣式模板,一鍵套用。

SpreadJS 單元格的樣式在不同的層級結(jié)構(gòu)中具有不同的優(yōu)先級別, 如下: 單元格 > 行 > 列

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

精確選擇單元格

SpreadJS 可以設(shè)定最小選擇單元為:單元格、行或列的任意一項,例如設(shè)定最小選擇列,點選任意單元格會選中整列:

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

自定義行為

SpreadJS 支持撤銷/取消撤銷操作,快捷鍵為 ctrl z/ctrl y。

表單保護

通過設(shè)置 isProtected 屬性可以保護表單不被用戶編輯。設(shè)置 protectionOptions 屬性可以限制用戶的各種行為。

例如過濾權(quán)限被放開時,點列頭下拉框可以進行過濾操作,取消該權(quán)限則點不動向下箭頭:

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

允許插入行時,在行頭處點擊右鍵,即可插入新行:

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

分組列

對于有分層結(jié)構(gòu)的數(shù)據(jù),可以通過 SpreadJS 讓數(shù)據(jù)呈現(xiàn)樹形結(jié)構(gòu),如下圖。此外,用戶還可以自定義圖標、控制 checkbox 顯示狀態(tài):

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

基本函數(shù)、INDIRECT、通配符

setFormula 用于設(shè)置基本函數(shù),如求平均值、合計、最大值和最小值,INDIRECT 函數(shù)用于返回特定單元格的內(nèi)容,如 INDIRECT(“B4”)返回B4單元格的內(nèi)容。需要注意:若傳參不帶引號,則返回單元格所指向的內(nèi)容,如 INDIRECT(E4)返回的是 E4 所指向的單元格的數(shù)據(jù)。

如下圖:INDIRECT(“B4”) = 丁玉琴

INDIRECT(E4) = 丁玉琴

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

SpreadJS Demo 示例

以下是我在學(xué)習(xí) SpreadJS 表單的過程中,自己寫的 Demo 示例,供大家參考。

  • sheetDemo1.zip
  • sheetDemo2.zip
  • sheetDemo3_protect_outlineCol.zip
  • unction.zip

本周學(xué)習(xí)計劃二:SpreadJS 的函數(shù)

自定義函數(shù)

SpreadJS 內(nèi)置了很多函數(shù),包括很多常用的基本函數(shù),但是在遇見較為特殊的方法,基本函數(shù)無法滿足需求時,可以添加自定義函數(shù)。

例如,根據(jù)三角形的底和高來求三角形的面積,我們可以自定義函數(shù) calcuArea,用 addCustomFunction 方法將該自定義函數(shù)加在表單中,再使用 setFormula 給單元格綁定自定義函數(shù)。

數(shù)組公式

SpreadJS 使用 setArrayFormula 方法來設(shè)置數(shù)組公式。如下圖,E5 到 E8 便是使用數(shù)組公式計算出來的三角形面積

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

異步函數(shù)

當計算方法或者數(shù)據(jù)不能立刻獲取時,可以使用異步函數(shù)來進行計算。SpreadJS 可使用添加自定義函數(shù)的方法來添加并定義異步函數(shù),通過設(shè)置 defaultValue 的值,在計算結(jié)果還出來時代替計算結(jié)果,通過使用 evaluateAsync 方法來進行計算,并且在異步計算完畢后使用context.setAsyncResult 方法返回 SpreadJS 。

如下圖,E8位置的數(shù)據(jù)使用異步函數(shù)計算,在前三秒顯示【計算中… 】,計算好后顯示結(jié)果35:

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

您也可獲取當前時刻的異步函數(shù),如每秒獲取一次當前時刻:

從零開始,SpreadJS 新人學(xué)習(xí)筆記「第3周」(spreadjs教程)

SpreadJS Demo 示例

以下是我在學(xué)習(xí) SpreadJS 函數(shù)的過程中,自己寫的Demo示例,供大家參考。

  • function.zip

OK,今天先記錄到這里,下一周學(xué)習(xí)計劃: SpreadJS 的數(shù)據(jù)綁定、臟數(shù)據(jù)和單引號前綴。

PS:文中提到的學(xué)習(xí)視頻和示例源碼,都已經(jīng)上傳到 SpreadJS 官網(wǎng)的【入門視頻】中,歡迎大家點擊了解更多,觀看學(xué)習(xí)。

關(guān)于葡萄城

賦能開發(fā)者!葡萄城公司成立于 1980 年,是全球領(lǐng)先的集開發(fā)工具、商業(yè)智能解決方案、管理系統(tǒng)設(shè)計工具于一身的軟件和服務(wù)提供商。西安葡萄城是其在中國的分支機構(gòu),面向全球市場提供軟件研發(fā)服務(wù),并為中國企業(yè)的信息化提供國際先進的開發(fā)工具、軟件和研發(fā)咨詢服務(wù)。葡萄城的控件和軟件產(chǎn)品在國內(nèi)外屢獲殊榮,在全球被數(shù)十萬家企業(yè)、學(xué)校和政府機構(gòu)廣泛應(yīng)用。

版權(quán)聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶自發(fā)貢獻,該文觀點僅代表作者本人。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔相關(guān)法律責任。如發(fā)現(xiàn)本站有涉嫌抄襲侵權(quán)/違法違規(guī)的內(nèi)容, 請發(fā)送郵件至 舉報,一經(jīng)查實,本站將立刻刪除。