2022-9-19 純純
表格已經(jīng)是現(xiàn)代電子計算機系統(tǒng)中重要的組成部分之一,從小學(xué)開始,我們就已經(jīng)在電腦課上學(xué)習(xí)如何使用 Office Excel 來制作電子表格。
那么我們?yōu)槭裁葱枰褂帽砀衲??因為我們有記錄和查詢?shù)據(jù)的需求。
在任何商業(yè)活動中,都會產(chǎn)生大量的數(shù)據(jù)信息,雖然我們發(fā)明了 SQL、Mysql 等數(shù)據(jù)庫語言記錄數(shù)據(jù),但最原始的數(shù)據(jù)記錄是沒有可讀性的。
所以,為了讓數(shù)據(jù)可以更好的展示,我們就必須借助可視性更強的圖形工具,即電子表格。通過 X、Y 軸構(gòu)建的網(wǎng)格系統(tǒng),將數(shù)據(jù)有序、清晰得羅列出來。
表格的重要性就體現(xiàn)在企業(yè)日常工作中對這些數(shù)據(jù)進行管理的需求和頻次上。
例如為電商 APP 開發(fā)了一套管理系統(tǒng),那么電商運營每天的工作,都要繞著其中銷售、物流、流水等重要模塊的數(shù)據(jù)打轉(zhuǎn),也就是圍繞著表格展開工作。
對于多數(shù)管理系統(tǒng)而言,數(shù)據(jù)查詢、管理都是非常重要且高頻使用的功能,所以常規(guī)項目中會包含大量的表格頁面。
甚至,有的中小型項目的所有導(dǎo)航一級頁面,只有表格,而不存在其它頁面形式。所以,表格的優(yōu)劣對用戶工作效率和平臺體驗可以產(chǎn)生決定性的影響。
而優(yōu)秀的 B 端項目表格又不能只像 Excel 一樣可以使用固定的模版,不同項目、頁面、模塊對表格的可視需求天差地別,需要根據(jù)具體情況具體分析。
所以,這也是 B 端設(shè)計師的價值之一。一個優(yōu)秀的 B 端設(shè)計師勢必投入大量精力來提升對表格的認識和表格設(shè)計能力。
表格雖然細節(jié)設(shè)計上千差萬別,但在表現(xiàn)形式和閱讀順序上卻是基本一致的。
常規(guī)的表格必然包含表頭欄、列表、翻頁器三個部分,根據(jù)需求的不同,可能還會增加搜索欄、多選欄、操作欄等常見模塊。
主要是用來進行簡單的數(shù)據(jù)搜索和篩選的,當(dāng)搜索項較少的時候,就可以將搜索結(jié)合到表格組件內(nèi)。而搜索項較多時,則會把它們獨立成一個篩選模塊到表格組件的上方。
每個表頭代表一個對象的屬性,決定了下方每行對象要顯示的數(shù)據(jù)類型數(shù)量。
通常,表頭的設(shè)計會和下方列表設(shè)計有一定的區(qū)分,表頭文字有一定的標(biāo)題屬性,所以會通過背景色、分割線、文字加粗來增強對比。
列表則是縱向排列數(shù)據(jù)對象的模塊。每個數(shù)據(jù)對象占一行,行的高度根據(jù)內(nèi)容來制定。橫向列表高度和縱向表頭寬度重疊的區(qū)域稱為單元格,每個單元格展示表頭對應(yīng)的數(shù)據(jù)明細。
常規(guī) B 端項目表格都會限制列表一次展示的行數(shù),極少使用無限滾動加載的模式。因為當(dāng)數(shù)據(jù)包含成千上萬條時會對本地、服務(wù)器性能和交互方式帶來一系列的負面影響。
如果數(shù)據(jù)對象支持多選和批量操作,則我們會在第一列中添加選框,并將選中后的可操作選項放進操作欄中。
翻頁器是切換列表頁面的控件。通常大數(shù)據(jù)量的列表包含上千頁,所以翻頁器只會顯示開頭幾頁和最后一頁,省略中間的,并增加適合快速跳轉(zhuǎn)的功能。
除了表頭和列表內(nèi)容外,其它模塊內(nèi)容都根據(jù)實際需求應(yīng)用。任何表格設(shè)計的第一步都是制定大框架,即包含的模塊和對應(yīng)分布位置,再展開后續(xù)的細節(jié)設(shè)計。
B 端項目支持響應(yīng)式是今天行業(yè)的普遍需求,也就是頁面內(nèi)容隨著瀏覽器視圖寬度變更而變更。
不同頁面類型的響應(yīng)式邏輯各不相同,而表格是其中邏輯最復(fù)雜,也最難理解的一種。
表格響應(yīng)式規(guī)則通常在確定好框架以后制定,優(yōu)于視覺、交互設(shè)計,因為它對視覺和交互產(chǎn)生的影響非常大,是前置條件而不是通過設(shè)計稿逆推出來的。
表格的響應(yīng)式規(guī)則比較細碎,我根據(jù)下面的順序展開解釋:
- 表格的總寬響應(yīng)
- 表格的最小寬度
- 單元格的響應(yīng)邏輯
- 內(nèi)容的響應(yīng)邏輯
表格的響應(yīng)主要是寬度上的響應(yīng),整個表格的寬度區(qū)域隨父集元素的放大而放大。比如父級元素左右內(nèi)邊距為 20px,則表格整體寬度保持和父級 20px 的左右間距。
上方邏輯中表格可以無限延長,但它卻不能無限的縮短,因為你不可能做一個只有 10px,20px 寬的表格。
過窄的表格不僅支持不了內(nèi)容的正常顯示,也毫無任何使用體驗,所以我們要為表格確定一個最小的寬度。即瀏覽器視圖即使比這個寬度更小,表格也不會再縮小了。
最小的寬度可以結(jié)合前端柵格系統(tǒng)使用的 Breakpoint 規(guī)則來制定,如 Ant deisgn 中 SM:576px,或 MD:768px。
如果不了解柵格的段落規(guī)則,也可以 “憑感覺” 定,最小表格寬度通常在 560-640px,當(dāng)然,不管怎么定一定要提前和前端溝通,確定尺寸方案。
當(dāng)表格內(nèi)容少的時候,最小寬度只是相對較大寬度窄了一點而已。而當(dāng)表格內(nèi)容過多,最小寬度無論如何也不夠放的情況,那么就會使用橫向滾動的交互形式來隱藏超出內(nèi)容。
單元格響應(yīng)這是整個表格最復(fù)雜的一環(huán),橫向內(nèi)容會超出最小寬度的情況,就是由單元格規(guī)則決定的。
首先,單元格本身也有最小寬度,原因和前面一樣,1px、10px 寬的單元格沒有存在的意義。所以可以根據(jù)需要,制定多個等級的最小單元格寬度,應(yīng)用在不同的數(shù)據(jù)類型中。
假設(shè)表格中包含了 20 個表頭,分別使用了 10 個最小 24px 和 10 個最小 80 px 的,那么單元格的總寬最小就是 240+800 = 1040px。
所以當(dāng)父級整個表格視圖小于 1040px 的時候,內(nèi)容就會不夠顯示從而觸發(fā)左右滾動的條件。
當(dāng)上級表格寬度大于單元格最小總和時,那么單元格也就會隨之變寬。最簡單的響應(yīng)邏輯,就是為單元格寬設(shè)置百分比。比如 5 個單元格分別是父級寬度的 10%、10%、10%、20%、30%、20% ,那么在父級 1000px 的時候它們分別是 100px、100px、100px、200px、300px、200px。
只要確保百分比的總和是 100%,不管你單元格是比例均分(5個單元格等分各20%寬),還是獨立制定(上面案例),單元格寬都是等比縮放的狀態(tài)。
雖然好理解,但這種初級的做法帶來的問題也很多,那就是部分單元格沒有被 ”放大“ 的需求。比如常出現(xiàn)在第一列的多選框,或者部分標(biāo)簽單元格、固定操作按鈕單元格。
于是,為了預(yù)留給有需要的單元格更多的空間,提升體驗,就會對這些單元格實施定寬的方式,剩下的單元格繼續(xù)使用等比,只是計算的方法要減去定寬元素。
比如還是一個占比 20% 的單元格,在包含 2 個 48px 定寬單元格的 1000px 表格中,實際寬為:
(1000px - 2*48) * 20% = 180px
作為單元格的子級,內(nèi)容也可以獨立定義響應(yīng)的規(guī)則。主要包含 3 種情況:
- 無響應(yīng)
- 隱藏多余
- 換行顯示
無響應(yīng)就是顯示的內(nèi)容是固定的,比如多選框、縮略圖、單按鈕等單元格內(nèi)容,它們沒有大小變動的必要。
隱藏多余,則是主要應(yīng)用在文本內(nèi)容上,當(dāng)單元格寬度小于當(dāng)前文本所需寬度時,就會把多余的文字進行省略,這種做法適合應(yīng)用在一些原本就不是太重要的信息上。
比如原本是 ”上海徐家匯南丹路天主教堂一樓“ 變成 ”上海徐家匯南丹路天…“,之后再通過鼠標(biāo)懸浮彈出文字氣泡框的方式顯示所有文本。
而換行顯示,則是文本或多標(biāo)簽狀態(tài)下,一行不夠顯示就換行的做法。除非一開始單行行高預(yù)留了多行顯示的高度,否則多行內(nèi)容就會撐高單元格。
以上就是表格在響應(yīng)式模式下相關(guān)知識點。
隨著經(jīng)驗的積累,實戰(zhàn)經(jīng)驗豐富的 B 端設(shè)計師,就會在前期的規(guī)范環(huán)節(jié)制定出完整的表格響應(yīng)邏輯,應(yīng)用到前端框架開發(fā)和后續(xù)的設(shè)計,而不是做到哪定到哪。
表格首先是一個展示信息的組件,而單純依靠布局和排版技巧,并不能解決所有的信息展示問題。所以,針對網(wǎng)頁表格的局限性,我們要添加一些交互的細節(jié)來提升使用體驗。
例如,單頁表格數(shù)據(jù)量較大,有好幾屏高,往下滾動后看不見表頭,不能很好的識別單元格內(nèi)容。
或者,表頭屬性數(shù)量較多,需要左右滾動,但是每行數(shù)據(jù)要不然操作欄目看不見,要不然對應(yīng) ID 被滑走了等等。
所以,表格的框架就可以做懸浮固定的模式,將需要被持續(xù)露出的欄目懸浮固定。
當(dāng)然,除了單獨欄目的懸浮,也可以使用混合模式,比如表頭吸頂?shù)耐瑫r固定右側(cè)的操作欄。盡量將固定元素控制在 3 個以內(nèi),以免懸浮要素太多影響內(nèi)容的瀏覽。
還要注意,除了筆記本觸摸板和少數(shù)鼠標(biāo),一般用戶是沒有頁面左右滾動滾輪的,所以當(dāng)表格出現(xiàn)左右滾動情況以后,就一定要默認展示進度條,方便用戶操作。
第二步,就是和表頭相關(guān)的操作了。我們都知道常規(guī)表格頁面中,表格上方還會有個篩選區(qū)域,專門用來進行篩選相關(guān)的條件制定。
但是,部分項目需求中,會將篩選的功能整合到表頭欄目內(nèi),而很多新手甚至不能有效的區(qū)分篩選和排序的差異。
我們先對這兩者做一個明確的定義:
篩選 Filter:對要顯示的內(nèi)容設(shè)置篩選條件,不符合條件的將會被過濾隱藏
排序 Sort:對已有內(nèi)容的顯示順序進行條件設(shè)置,不會有內(nèi)容被過濾或隱藏
這看起來好像很容易理解,但會搞混的地方就在排序的應(yīng)用上。我們常規(guī)以為的排序,就像電腦文件夾列表一樣,通過點擊表頭來決定內(nèi)容通過哪個屬性來進行升序或者降序。
在這種 “樸素” 的設(shè)定中,篩選是以單個表頭屬性為標(biāo)準(zhǔn)的,有唯一性。比如在學(xué)生數(shù)據(jù)表格中,可以以 ID、姓名、年級、年齡或成績單個屬性進行列表排序,選中其中一個屬性其它屬性的排序就被取消了。
但是復(fù)雜的排序并不是 “唯一屬性” 的,而是多個屬性的并集,以及具備優(yōu)先級和排序模式。還用學(xué)生數(shù)據(jù)表格舉例:
優(yōu)先根據(jù)年齡降序排列,同年齡下根據(jù)班級升序排列,同班級再根據(jù)成績降序排列。
這里面疊加了三個屬性,年齡優(yōu)先級最好,然后班級次要,成績最后,我們用圖表的展示可以實現(xiàn)出下面這樣的形式:
再進一步,這是我們條件已經(jīng)確定才做出來的組件,要是要制定的屬性不確定,要制定的屬性數(shù)量也不確定,順序不確定,排序模式也不確定……
這種情況就肯定要應(yīng)用排序自定義條件的邏輯了,而表頭自定義一加,那邏輯就立馬復(fù)雜了,它的操作面板可能就長下圖這樣。
排序復(fù)雜了,并不代表篩選就不要了。部分項目的篩選除了在表格外的獨立篩選區(qū)域,還可能應(yīng)用表頭篩選模式。即以單個表頭緯度設(shè)置篩選條件,比如點擊 “年份” 表頭,設(shè)置起始和結(jié)束時間。
所以,只包含篩選的情況下,表頭的圖標(biāo)就不是排序而是漏斗,點擊后就要展開篩選設(shè)置面板進行操作。
而當(dāng)多表頭篩選和多表頭排序需求并存的時候,怎么解決?
這里只建議在表頭中留存篩選選項,因為篩選可以實現(xiàn)并集關(guān)系,即前后任何表頭添加篩選項都可以組成完整的篩選條件。但是,這種交互難以完成篩選優(yōu)先級排序。
所以,我們要將排序獨立成一個按鈕到表頭之外的地方,而不是強行讓兩者并存。尤其是不要設(shè)計出有的表頭是排序,有的表頭是篩選,甚至表頭的按鈕展開面板里又會有篩選又有排序……
表頭是針對列的操作,而針對行的操作,就是對單行列表的選擇、展開和進入了。
前面我們有說過,表格第一列往往放多選框,通過點擊選擇當(dāng)前列表行。它本身的交互并沒有太多需要注意的,只要針對行的交互如果不止選擇應(yīng)該如何平衡。
部分復(fù)雜項目喜歡在表格中添加 “套娃” 的需求。即單行數(shù)據(jù)可以向下展開二級數(shù)據(jù),或者更進一步到三級、四級。
同時,每個數(shù)據(jù)行往往還關(guān)聯(lián)詳情頁面,需要點擊展開后查看更細節(jié)的信息。
所以當(dāng)多種操作需求混合出現(xiàn)的時候,我們就要具體分析這些需求的優(yōu)先級了。到底是多選操作頻率最高,還是查看下級行,打開詳情頁。
這是為讓點擊整個數(shù)據(jù)行這個最便捷的交互可以關(guān)聯(lián)到最高頻的操作上。而其它低頻操作的交互則只限定在對應(yīng)的按鈕或圖標(biāo)上即可。
因為多選需求往往需要我們在一系列數(shù)據(jù)中選擇很多條數(shù)據(jù),一個小小的復(fù)選框不僅選擇起來麻煩,且通過查看右側(cè)的內(nèi)容篩選數(shù)據(jù)行,再用右手握鼠標(biāo)按需點擊最左側(cè)的多選框,是非常別扭的體驗。
還有一個需要注意的細節(jié),就是當(dāng)多選和展開下級列表共同出現(xiàn)的時候,選框和展開圖標(biāo)的排列。
通常一個數(shù)據(jù)行第一列的內(nèi)容,應(yīng)該是整行邏輯層級最高的元素。如果子數(shù)據(jù)行是被獨立出來需要單選,那么展開圖標(biāo)就要放到選擇前面。如果選擇數(shù)據(jù)包含了該行和所有子行,那么選擇就應(yīng)該在展開圖標(biāo)前面。
當(dāng)然,如果展開數(shù)據(jù)和父集就完全不是一種類型,用另一套屬性,那么它也就沒有被同時選中的需求和可能,不需要為它添加選擇框。所以,這種情況下多選框也應(yīng)該放在第一位。
最后,就是解決單元格的交互了。常見的單元格交互可以總結(jié)成下面這幾類:
- 點擊打開頁面
- 點擊復(fù)制內(nèi)容
- 點擊修改內(nèi)容
- 懸浮提示說明
點擊打開頁面很好理解,比如單元格內(nèi)的數(shù)據(jù)是鏈接、圖片、按鈕然后實現(xiàn)跳轉(zhuǎn)或彈窗。
而復(fù)制內(nèi)容,則有一些需要注意的細節(jié)。表格中有一些數(shù)據(jù)是沒有實際閱讀意義的,它的存在就是用來做特定的校對或者是復(fù)制出去,比如 ID 號、哈希值、訂單號等。
常規(guī)的做法是直接在右側(cè)添加一個復(fù)制圖標(biāo),但對于一些偏復(fù)雜的表格來說,所有可復(fù)制的單元格都加復(fù)制圖標(biāo)是非常影響瀏覽體驗的。
所以,我的建議是都是默認隱藏復(fù)制圖標(biāo),只有當(dāng)鼠標(biāo)移動到對應(yīng)單元格的時候會顯示。同時,這個圖標(biāo)可以覆蓋到數(shù)據(jù)上層,因為既然鼠標(biāo)移動過來為了復(fù)制,那么數(shù)據(jù)被遮擋在這階段自然無關(guān)緊要,為整體頁面預(yù)留空間
這樣的操作按鈕隱藏浮現(xiàn)方式,也適用于單元格修改的操作。但是,和復(fù)制不同,單元格信息編輯通常是編輯文本信息,還有后續(xù)的操作步驟。
如果點擊進行文本編輯,那么建議在該表格打開一個新的輸入浮窗,且浮窗內(nèi)輸入框文本和原來文本位置持平實現(xiàn)順暢的步驟轉(zhuǎn)換。
同時建議,為了防止誤操作,盡量增加確定、取消按鈕,防止誤操作覆蓋原有數(shù)據(jù)且無法撤銷。
最后就是單元格的懸浮提示了。B 端控件中的氣泡框就是用來做提示的控件,但它只是手段。為什么需要懸浮提示,提示什么內(nèi)容是我們需要考慮的。
對于及其復(fù)雜的表格來說,往往是沒辦法支持所有數(shù)據(jù)都完整展示的,我們會在使用省略號對它進行截斷。但截斷不意味著用戶完全不需要在表格查看到完整的信息。
所以,就可以通過氣泡的做法,將信息呈現(xiàn)給用戶。而呈現(xiàn)過程中,盡量確保鼠標(biāo)可以移動到氣泡上復(fù)制里面的文字內(nèi)容(和全部復(fù)制不一樣),而不是鼠標(biāo)移走就直接關(guān)閉消失。
熟練運營這幾個交互方式,并統(tǒng)一對應(yīng)的使用規(guī)則,就能確保整個項目的表格單元格操作預(yù)期的一致,不需要逐一進行嘗試和鑒別。
作者:酸梅干超人
藍藍設(shè)計( www.b186.net )是一家專注而深入的界面設(shè)計公司,為期望卓越的國內(nèi)外企業(yè)提供卓越的UI界面設(shè)計、BS界面設(shè)計 、 cs界面設(shè)計 、 ipad界面設(shè)計 、 包裝設(shè)計 、 圖標(biāo)定制 、 用戶體驗 、交互設(shè)計、 網(wǎng)站建設(shè) 、平面設(shè)計服務(wù)、UI設(shè)計公司、界面設(shè)計公司、UI設(shè)計服務(wù)公司、數(shù)據(jù)可視化設(shè)計公司、UI交互設(shè)計公司、高端網(wǎng)站設(shè)計公司、UI咨詢、用戶體驗公司、軟件界面設(shè)計公司
藍藍設(shè)計的小編 http://www.b186.net