原創(chuàng)|使用教程|編輯:郝浩|2013-06-08 14:28:06.000|閱讀 283 次
概述:假設(shè)你想要顯示一個(gè)由一百萬行十列計(jì)算值組成的大型工作表(比如加法或乘法表)。如果使用的是默認(rèn)的工作表數(shù)據(jù)模型,將需要計(jì)算和存儲所有的一千萬個(gè)值,將會消耗大量的時(shí)間和內(nèi)存。
# 界面/圖表報(bào)表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
相關(guān)鏈接:
用戶可以使用一個(gè)工作表模型作為新的工作表模型。例如,制作一個(gè)自定義數(shù)據(jù)模型。使用一個(gè)自定義的數(shù)據(jù)模型需要?jiǎng)?chuàng)建一個(gè)ISheetDataModel類,然后設(shè)置一個(gè)實(shí)例到SheetView.Models.Data屬性。
假設(shè)用戶不需要任何備選的接口,那么ISheetDataModel是唯一要求的接口。
所有可選的接口都是由DefaultSheetDataModel實(shí)現(xiàn)的,所以如果你想要在數(shù)據(jù)模型上執(zhí)行,對DefaultSheetDataModel子類而言會更簡單。
在BaseSheetDataModel中,Changed事件也會執(zhí)行。
》》》免費(fèi)下載Spread Studio for .NET最新版
在某些情況下,用戶處于性能原因的考慮,可能需要?jiǎng)?chuàng)建自己的自定義數(shù)據(jù)模型。比如,假設(shè)你想要顯示一個(gè)由一百萬行十列計(jì)算值組成的大型工作表(比如加法或乘法表)。如果使用的是默認(rèn)的工作表數(shù)據(jù)模型,將需要計(jì)算和存儲所有的一千萬個(gè)值,將會消耗大量的時(shí)間和內(nèi)存。使用Spread可以有效的對這一問題進(jìn)行改善,示例代碼如下:
示例:
C#
for (r = 0; r < 1000000; r++) for ( c = 0; c < 10; c++) spread.Sheets[0].Cells[r,c].Value = r + c;
示例:
C#
class ComputedDataModel : BaseSheetDataModel { public override int RowCount { get { return 1000000; } } public override int ColumnCount { get { return 10; } } public override object GetValue(int row, int column) { return row + column; } }
本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng)或翻譯。歡迎任何形式的轉(zhuǎn)載,但請務(wù)必注明出處、不得修改原文相關(guān)鏈接,如果存在內(nèi)容上的異議請郵件反饋至chenjj@fc6vip.cn
文章轉(zhuǎn)載自:慧都控件網(wǎng)