公主的腿间舌奴们np肉_国产在热线精品视频99公交_公主车上荫蒂添的好舒服_公侵犯人妻中文字慕一区二区_公么大龟弄得我好舒服秀_公交车+多人+高cH文章推荐_日本熟妇另类视频在线播放

B端設(shè)計指南 - 樹形選擇

2022-1-6    ui設(shè)計分享達(dá)人

樹形選擇

關(guān)于樹形選擇,我們必須先知道它的基礎(chǔ)概念,“樹” 究竟是什么?我們先來看看樹狀結(jié)構(gòu)的定義


樹狀結(jié)構(gòu):

樹狀結(jié)構(gòu)其實是作為一種層次結(jié)構(gòu)化的表達(dá)方式,它能夠?qū)涞某橄蟪鰜肀磉_(dá)完整的構(gòu)造關(guān)系,為什么叫做樹,是因為它更像是一個上下顛倒的樹,根部在最頂端,枝葉反而變?yōu)橄路健?

同樣在對樹狀結(jié)構(gòu)的整體命名上,也遵循了與之類似的表達(dá)方式:



節(jié)點(Node):是樹狀結(jié)構(gòu)當(dāng)中的基本單位,使用節(jié)點可以表示 不同數(shù)據(jù)間的 組成關(guān)系(從屬關(guān)系與并列關(guān)系)通常節(jié)點會分為幾類特殊情況。


1.根節(jié)點:整個樹狀結(jié)構(gòu)的開端被稱為根節(jié)點。一個樹狀結(jié)構(gòu)一定只有一個根,在思維導(dǎo)圖中,根節(jié)點就代表著它的開端,用于延展出更多的樹狀結(jié)構(gòu)。不過在目前的樹形選擇當(dāng)中,因為對易用性的要求,通常會隱藏根節(jié)點,只展示子節(jié)點。而根節(jié)點隱藏在 標(biāo)題、選項文本 當(dāng)中。


2.子節(jié)點:根節(jié)點之外的節(jié)點被稱為子節(jié)點。一個樹狀結(jié)構(gòu)子節(jié)點數(shù)量是沒有具體限制,在樹形選擇當(dāng)中是直接展示出來的部分。


3.葉節(jié)點:沒有連接到其他子節(jié)點的節(jié)點。葉節(jié)點屬于一類特殊的子節(jié)點,它是整個樹狀結(jié)構(gòu)的最末端節(jié)點,在樹形選擇當(dāng)中是一個重要的概念,下面會展開來講。

分支(Branch):節(jié)點之間的鏈接,在我們樹形選擇當(dāng)中,分支的線條可以選擇顯隱。其搭配的使用方式也有所不同


同時我們還會用到節(jié)點的幾個基礎(chǔ)的概念:

節(jié)點層級:指當(dāng)前節(jié)點所在的層級,比如根節(jié)點為第一層級,根的子節(jié)點為第二層級,以此類推;

節(jié)點高度:對于某一節(jié)點的高度,便是該節(jié)點下所有葉節(jié)點從上到下的個數(shù);

節(jié)點深度:指該節(jié)點到根節(jié)點的唯一路徑長度,深度與層級較為類似。


樹狀結(jié)構(gòu)究竟出現(xiàn)在生活中的什么地方呢?樹狀結(jié)構(gòu)對于我們又有什么用呢?大家可能理解上會覺得很枯燥,我給大家舉一個例子:


回憶一下我們小學(xué)使用字典時的場景,首先我們是先通過聲母,去確定這個漢字的大概的頁數(shù)范圍,然后通過韻母去確定這個漢字的詳細(xì)位置,最后通過音調(diào)找到想要尋找的漢字:


其實字典的設(shè)計,便是一個典型的樹形結(jié)構(gòu)。而在 B端系統(tǒng)中我們常見的公司組織架構(gòu)、省 市 縣 地址選擇、在線教育的班級結(jié)構(gòu) 等等,這些都是使用了完整的樹形結(jié)構(gòu)。


采用樹形可以快速進(jìn)行結(jié)構(gòu)化的表達(dá),其目的是為了用戶能夠快速地增刪改查,想要更多了解結(jié)構(gòu)化表達(dá)的同學(xué)推薦大家看一本書《金字塔原理》,里面講了非常多的邏輯化思維、表達(dá)的方法與內(nèi)容,內(nèi)容比較多,而這種思維其實在我們工作生活中都能夠用到。



樹狀結(jié)構(gòu)組成:

1.層級縮進(jìn)

為了將樹的整個結(jié)構(gòu)完整的表達(dá)出來,會使用層級縮進(jìn)的方式進(jìn)行區(qū)分,通常會使用 8px 對下一級節(jié)點進(jìn)行縮進(jìn),這樣能夠表達(dá)更為完整的層級關(guān)系。

這里要注意,如果想要更為強(qiáng)調(diào)樹形選擇的層級關(guān)系或者樹形內(nèi)容本身就比較多的情況下,可以見解 Coding 編輯器的思路,即:將縮進(jìn)內(nèi)容使用“分支線”進(jìn)行表達(dá),更明確清晰。 這里使用層級線后,折疊圖標(biāo)也會有所不同,下面有明確解釋。


2.折疊圖標(biāo)(節(jié)點按鈕)

主要是將節(jié)點下的所有樹葉與子節(jié)點進(jìn)行展示,在整個樹的結(jié)構(gòu)中,折疊圖標(biāo)一般分為兩種:三角折疊、方形折疊

三角折疊:為頁面層級較少時使用。因為在較少的層級下,用戶不用特意去思考當(dāng)前節(jié)點所在層級究竟在哪。

方形折疊: 更多與頁面層級線進(jìn)行配合使用,通過層級縮進(jìn),將頁面層級線標(biāo)識清楚,能夠更好的在多層級情況下進(jìn)行合理區(qū)分。


3.選擇控件

整個樹形結(jié)構(gòu)依舊是在選擇錄入框架下,分為單選和多選。因此需要對其類型有所展示,特別是在多選的場景下,一定要標(biāo)明它的類型,方便用戶進(jìn)行理解使用。

通常這個控件可以在單選的時候進(jìn)行隱藏,這里先按下不表,我在樹形選擇的類型當(dāng)中深入給同學(xué)們進(jìn)行分析理解。


4.選項文本

注意字?jǐn)?shù)限制、超出后如何處理即可,我就不做過多介紹。



樹形選擇的類型:

在講樹形選擇之前,我先為大家講解關(guān)于與其相關(guān)的同類型產(chǎn)品,為了方便大家的記憶,我選擇出了兩類不同的組件進(jìn)行對比,感興趣的同學(xué)可以關(guān)注“CE青年” 后臺回復(fù)樹形對比進(jìn)行查看。我通過視頻的形式為大家進(jìn)行了講解,相信大家在看完之后一定會有所收獲。

1.單選樹

單選樹只能選擇葉節(jié)點,也就是需要將每個樹展開過后才能進(jìn)行選擇。

它是一個較為傳統(tǒng)的選擇方式,因為它的選擇熱區(qū)較小并且理解成本較高,因此這種方式不太滿足現(xiàn)如今對于B端產(chǎn)品效率提升方面的要求,并且要求十分特殊,因此使用較少,現(xiàn)多以單選節(jié)點樹為主。

2.單選節(jié)點樹

單選節(jié)點樹與單選樹最大的區(qū)別在于其能夠選擇子節(jié)點,這樣可快速選擇該子節(jié)點以及其各種葉節(jié)點。

同時傳統(tǒng)的單選節(jié)點樹中是采取單選按鈕的方式,隨著對B端要求的不斷提高,并且在樹的功能越發(fā)的復(fù)雜過后,幾乎取消了 單選按鈕 的形式,取而代之的是將整個 文本標(biāo)簽 作為選擇的熱區(qū),用戶點擊過后即可進(jìn)行選擇。

因此在樹形選擇當(dāng)中,逐漸將單選節(jié)點樹演變成由兩部分熱區(qū)所組成的一個控件:



在左側(cè),主要以樹類型的展開折疊操作,熱區(qū)通常就是圖標(biāo)折疊圖標(biāo)這一部分;

在右側(cè),以選擇該選項、節(jié)點的操作為主,熱區(qū)范圍以整個選項文本作為基礎(chǔ),進(jìn)行延展即可。

這里還是提示以下新讀者,這類選擇一定要進(jìn)行 Hover 狀態(tài)處理,不然用戶無法根據(jù)光標(biāo)的變化判斷是否可點擊,當(dāng)然老讀者跳過就行~

3.多選節(jié)點樹

大家在對比單選與多選時會發(fā)現(xiàn),為什么不會存在多選樹?不存在只選擇選項的多選呢?

思考時間又到了,別忘下劃,自己先想想呢~

雖然在理論上會存在多選樹的情況,但是它存在的價值比較詭異。首先在樹的節(jié)點當(dāng)中,我選擇一個子節(jié)點就是選擇該節(jié)點下的所有。因此可以說是選擇了一個節(jié)點;或者說它選擇了該節(jié)點下的多個選項,因此在實際情況中這類場景過于的少,更多會用多選節(jié)點樹進(jìn)行代替。


當(dāng)然,多選節(jié)點樹與單選節(jié)點樹在結(jié)構(gòu)上是十分接近的,就是將復(fù)選框展示出來,方便大家進(jìn)行選擇。考慮到大家經(jīng)驗不足,建議這里復(fù)選框放在折疊圖標(biāo)前側(cè),原因有二:


  • 在樹形選擇后續(xù)的拓展當(dāng)中,經(jīng)常會遇到選擇增加一些操作功能,比如 新增、刪除、復(fù)制、粘貼、拖動排序。我看很多設(shè)計師最開始因為種種原因?qū)⑦x擇組件部分放在后側(cè),導(dǎo)致之后的操作無法進(jìn)行更多的拓展,隨之崩潰,對樹形選擇又是一頓亂造~

  • 現(xiàn)有的基礎(chǔ)架構(gòu)基本都是沿用了這類設(shè)計,可減少前端同學(xué)的工作量,同時也減少他 BUG 的產(chǎn)生。


多選節(jié)點樹的使用場景非常多,我舉一個大家在樹形選擇中都會犯的例子,希望大家能夠多理解其中存在的特殊邏輯:


比如在一個大型上市公司當(dāng)中,我作為老板會去設(shè)定整個“設(shè)計部”的權(quán)限,并且想要得到的效果是之后有任何新員工都是使用這個權(quán)限。如果作為一個新人設(shè)計師,很容易就會使用多選節(jié)點樹,將整個組織架構(gòu)進(jìn)行選擇,但是這樣的選擇與用戶實際想要的內(nèi)容是存在較大差異的。


在產(chǎn)品設(shè)計中,對于上訴的“設(shè)計部”這個概念其實是一個動態(tài)數(shù)據(jù),即在之后新增到“設(shè)計部”的所有員工,我不必再去權(quán)限管理中重新配置。我們遇到動態(tài)數(shù)據(jù)的情況時,首先不建議大家采取樹形選擇,因為首先對于這個概念的理解成本很高,無法通過樹形選擇這樣的方式讓用戶理解;同時系統(tǒng)對于這類動態(tài)數(shù)據(jù)的情況都建議特殊處理,至于怎么處理,大家可以在評論區(qū)討論,我也會在后續(xù)文章當(dāng)中為大家進(jìn)行講解。


樹形選擇的優(yōu)點

易理解:

因為樹狀結(jié)構(gòu)本身就已經(jīng)存在很久,早在 DOS 計算機(jī)時代就有它的影子,經(jīng)過長期累月的發(fā)展,用戶在理解上也會相對更加容易


快瀏覽:

在數(shù)據(jù)量特別大的時候,能夠根據(jù)子節(jié)點優(yōu)先找到自己想要的葉節(jié)點,從而提升選擇效率,與《選擇錄入02》當(dāng)中講到的 Tab選擇十分類似,沒看過的同學(xué)建議先去看看。


看結(jié)構(gòu):

結(jié)構(gòu),能夠輔助人們進(jìn)行快速記憶,從而對整體框架有著更深了解。而樹形選擇正是有了這種結(jié)構(gòu)能夠更為方便的讓更多人熟知,從而更快了解業(yè)務(wù)。


樹形選擇常見誤區(qū):

數(shù)據(jù)量

首先對于樹形選擇本身的控件形式,你就需要去分析其能承載的內(nèi)容數(shù)據(jù)量。應(yīng)該是在什么范圍內(nèi)較為合適。

當(dāng)數(shù)據(jù)量過大時一定會出現(xiàn)異步加載、數(shù)據(jù)分頁等諸多情況,因此在設(shè)計中,需對這類情況進(jìn)行設(shè)計。

全選功能

全選功能本身較為簡答,無外乎就是一個復(fù)選框的事情,但是在上面提到的數(shù)據(jù)量過大 + 全選的存在,會有些問題還需要大家進(jìn)行留意。

鍵盤映射

在樹形選擇當(dāng)中,都可以采取鍵盤操作從而提高效率。基本規(guī)則是:

↑鍵:向上切換同級節(jié)點;從第一子節(jié)點,順序返回父節(jié)點;

↓鍵:向下切換同級節(jié)點;順序進(jìn)入已展開的第一子節(jié)點;

←鍵:關(guān)閉當(dāng)前級別節(jié)點;返回上一級父節(jié)點;

→鍵:展開子節(jié)點列表;順序進(jìn)入已經(jīng)展開的第一子節(jié)點;

回車鍵:提交當(dāng)前 foucs 的節(jié)點選項;

樹形選擇是較為常見的一類方式,但由于大家對 基本的樹形結(jié)構(gòu) 認(rèn)識不足,導(dǎo)致對其設(shè)計會有許多誤區(qū)。

關(guān)于樹形選擇大家還有什么疑惑,可以在評論區(qū)咱們一起討論~

任何一個新穎的設(shè)計浪潮,都會影響設(shè)計師的設(shè)計表達(dá)。我們能做的就是感受浪潮、尋找源頭、思考走向,隨時精準(zhǔn)有力的擁抱變化。


藍(lán)藍(lán)設(shè)計建立了UI設(shè)計分享群,每天會分享國內(nèi)外的一些優(yōu)秀設(shè)計,如果有興趣的話,可以進(jìn)入一起成長學(xué)習(xí),請掃碼ben_lanlan,報下信息,會請您入群。歡迎您加入噢~~希望得到建議咨詢、商務(wù)合作,也請與我們聯(lián)系。

文章來源:站酷 作者:CE青年
分享此文一切功德,皆悉回向給文章原作者及眾讀者.

免責(zé)聲明:藍(lán)藍(lán)設(shè)計尊重原作者,文章的版權(quán)歸原作者。如涉及版權(quán)問題,請及時與我們?nèi)〉寐?lián)系,我們立即更正或刪除。

藍(lán)藍(lán)設(shè)計tweetduck.com )是一家專注而深入的界面設(shè)計公司,為期望卓越的國內(nèi)外企業(yè)提供卓越的UI界面設(shè)計、BS界面設(shè)計 、 cs界面設(shè)計 、 ipad界面設(shè)計 、 包裝設(shè)計 、 圖標(biāo)定制 、 用戶體驗 、交互設(shè)計、 網(wǎng)站建設(shè) 、平面設(shè)計服務(wù)


日歷

鏈接

個人資料

存檔

海兴县| 原平市| 普格县| 临洮县| 吴堡县| 榆中县| 威远县| 周宁县| 克山县| 北碚区| 房山区| 小金县| 游戏| 连江县| 巩留县| 城固县| 鄂尔多斯市| 眉山市| 莎车县| 重庆市| 福鼎市| 合江县| 云林县| 会同县| 普安县| 马尔康县| 泽库县| 高密市| 娄底市| 五指山市| 新建县| 铜山县| 阜宁县| 奉化市| 武平县| 定兴县| 阿瓦提县| 闽侯县| 双辽市| 互助| 苍南县|