寫在前面
金秋十月,iView 4.0 如約而至。但是標題資訊量有點大,所以先來解讀一下標題。
iView 作者 Aresn 於 2019 年創辦了北京檢視更新科技有限公司,開始自由、全職地維護 iView 及其相關的軟體。View UI 即為原先的 iView,從 2019 年 10 月起正式更名為 View UI,並使用全新的 Logo。iView 作者將在新倉庫 https://github.com/view-design/ViewUI 繼續開發 iView 4.0 和後續版本,以及維護工作。原倉庫 iView 作者不再繼續提交內容。
簡單說就是,我們將 GitHub 遷移到了:
https://github.com/view-design/ViewUI
對於絕大部分使用者來說,使用沒有任何影響,之後的 issue 和 pr 也請大家到新的倉庫進行提交,當然包括 Star!
請相信,全新的 View UI 元件庫會帶來更強大的功能和更出色的體驗。由於現在已經全職維護,這裡也可以向大家保證,每 1~2 周迭代一個版本。
更新方法
4.0 版本的核心是功能增強和體驗優化,基本沒有不相容的,大家可以放心升級,主要的更新內容下文會逐一介紹。
更新方法很簡單,修改 package.json
中 iview 的版本號為 4.0.0:
"dependencies": {
"iview": "^4.0.0"
}
然後執行 npm update iview
即可。
同時,我們也提供了一個新的 npm 包 view-design,如果你是初次使用 View UI,也可以這樣安裝:
npm install view-design --save
或
npm install iview@4.0.0 --save
主要更新內容
本次的 4.0 版本有超過 50 項更新。
UI
UI 方面,主要是將原先的基礎字號由 12px 調整為了 14px。現在的電腦螢幕越來越大,解析度也越來越高,14px 的基礎字號會更加實用,而且也是大勢所趨。
對應的,很多元件的尺寸會稍微變大,比如所有的 Form 系列元件(Button、Select、Input 等等)的尺寸調整為了 40px(large)、32px(default)、24px(small)。
Button 的高度計算方式由原先的 padding 調整為了固定 height。
還有很多元件的 UI 也進行了微調,比如 Alert、Notice、Modal、Card 等等,整體更統一、規範。
下圖是兩個版本的尺寸對比:
新增列表元件 List
List 元件是最基礎的列表展示,可承載文字、列表、圖片、段落,常用於後臺資料展示頁面。
全域性配置
全域性配置中,新增 capture
選項,可以配置所有元件預設的 capture 模式,預設為 true。
capture 是瀏覽器的一種預設行為,如果開啟,當可下拉的元件(例如 Select)處於展開狀態時,點選外部操作不會立即響應,而是先收起下拉選單,再次點選才會響應操作。
如果不需要該特性,可以通過全域性配置,將 capture 設定為 false。
Table 表格
Table 表格元件是大家最關心的,4.0 我們提供了更多新的功能:
1.拖拽表頭調整列寬
列 column 新增加了屬性 resizable
,設定為 true 時,滑鼠在表頭對應列的分割線上,就可以拖拽來調整列寬了:
2.合併行或列
新增了 span-method
屬性,可以自定義合併行或列,也就是可以合併單元格了,通過該屬性的配置,是可以對任意的行或列進行合併的:
3.表尾合計
新增了 show-summary
屬性,設定為 true 時,會在表尾顯示一個合計行,自動對該列數值求和。同時也新增了 summary-method
和 sum-text
來自定義合計的演算法或文案:
4.預設樣式不帶外側邊框
4.0 起 Table 表格元件的外輪廓預設不帶邊框了,更簡潔,除非設定 border
屬性。
這幾個功能給力吧,更給力的功能我們還會在 4.x 之後的幾個版本中更新哦!
Form 表單
1.新增屬性 disabled
如果想讓 Form 元件內的所有表單元件,例如 Button、Input、Select、Radio、Checkbox 等(View UI 的所有表單元件都支援)都禁用,以前的做法是要給每一個元件逐個加 disabled,很麻煩,現在只需要給外層的 Form 元件設定 disabled
屬性就可以了:
2.新增屬性 hide-required-mark
給表單 Form 設定了校驗規則中的 required
,也就是必填,對應的 FormItem 的 label 前就會有一個紅色的星號 *。但是往往一個長表單,都顯示必填的 * 看起來是沒必要的,所以只需要給 Form 開啟 hide-required-mark
屬性,就不顯示必填的星號了。
3.新增屬性 label-colon
開啟該屬性,在 FormItem 的 label 名稱後會自動加冒號:,不用再一個個配置了。
4.新增事件 @on-validate
任一表單項被校驗後觸發,返回表單項 prop、校驗狀態、錯誤訊息。
Select 選擇器
1.新增屬性 allow-create
及事件 @on-create
在 filterable 模式下,開啟屬性 allow-create
可以通過在輸入框中輸入文字來建立新的條目。輸入新條目後,按下Enter鍵即可新建條目。
2.Option 元件新增屬性 tag
Option 元件新增屬性 tag
,設定後,在多選時,標籤將優先顯示設定的內容。
多選,選中的標籤,預設顯示的就是 label,而在遠端搜尋的一些場景中,只有 label 會不夠用,所以新增了 tag 這一屬性。
Input 輸入框
1.新增屬性 show-word-limit
開啟屬性 show-word-limit
可以顯示字數統計,配合 maxlength 屬性來限制輸入長度:
2.新增屬性 password
在 type="password" 時,開啟屬性 password
可以切換顯示隱藏密碼:
Slider 滑塊
新增屬性 marks
設定屬性 marks
可以顯示標記。標記的 key 取值應該在閉合區間 [min, max] 內。標記點也可以通過 style 和 label 自定義樣式:
Switch 開關
1.開關背景顏色
新增屬性 true-color
和 false-color
,可以自定義背景色:
2.阻止切換
新增屬性 before-change
,如果設定,並返回 Promise,可以阻止切換,經常用於切換時請求資料,或二次確認的情況,可以配合 loading 來使用。
Progress 進度條
1.百分比內顯
新增屬性 text-inside
,開啟後,可以將百分比顯示在進度條內部:
2.漸變色
屬性 stroke-color
設定為陣列時,可以顯示為漸變色了,該特性 Circle 進度環元件也支援:
Message 全域性提示
帶背景色
新增屬性 background
, 開啟後,通知提示會顯示背景色:
Radio 單選 / Checkbox 多選
新增屬性 border
,支援帶邊框的樣式:
Page 分頁
新增屬性 disabled
,開啟後可以禁用分頁元件:
其它元件還有很多更新:
Badge 徽標數
- 新增屬性
color
,可以設定更多的狀態點顏色及自定義顏色。 - 新增 slot
count
,設定時,可以自定義角標顯示內容(去角標背景),數值 count 將無效。 - 新增 slot
text
,設定時,可以自定義角標顯示內容(帶角標背景),數值 count 將無效。亦可自定義狀態點模式下的 text 內容。
Tabs 標籤頁
- 標籤頁過多時,在標籤頁位置可以使用滑鼠滾動。
- 標籤頁過多時,左右箭頭距離增加。
AutoComplete 自動完成
- placement 屬性支援全方向。
- 修復點選元件外部關閉浮窗後,輸入框仍然聚焦的問題。
- 修復 disabled 模式下,聚焦顯示外輪廓的問題。
Card 卡片
- 新增屬性
to
、target
、replace
、append
,支援跳轉連結。
Tag 標籤
- 新增屬性
size
,可以設定不同的尺寸,可選值為 large(大號)、medium(中號)、default(預設)
Avatar 頭像
- 尺寸屬性 size 支援具體的數值。
Steps 步驟條
- Step 元件新增具名 slot
title
、content
和icon
。 - Steps 改用 flex 佈局,修復最後一列寬度不正確的問題。
其它修復:
- 修復 Button、Menu 等帶有跳轉功能元件在 vue-router 3.1+ 版本跳轉報錯的問題。
不相容更新
- DropdownItem 開啟 disabled 屬性後,Dropdown 不再觸發 @on-click 事件。
- Table 預設樣式不再帶有外側邊框。
後記
這波更新很給力吧!
iView 已經有 3 年多的沉澱,今天更名為 View UI 也是一個全新的開始。我知道市面上對我們商業化有不同的看法,但 View UI 的初衷是永不變的,會永遠免費開源,也會永遠更新下去,給大家不斷帶來期望和驚喜。
但是為了更好的服務企業使用者,也為了我的公司得以生存,商業化的產品是在所難免的。如果 View UI 對你的公司或團隊節省了成本,提高了開發效率,或者想使用更豐富的高階元件、強大的整套中、後臺前端解決方案,歡迎購買我們的專業版產品 View UI Pro 和 Admin Pro。
最後附上專業版地址,可以線上體驗:
Admin Pro 介紹:https://pro.iviewui.com/admin-pro
Admin Pro 線上預覽:https://adminpro.iviewui.com
View UI Pro:https://pro.iviewui.com/pro
之後,我們還會通過公眾號分享更多的內容,歡迎關注: