视图更新科技发布 View UI 组件库(即 iView 4.0),超过50项更新_viewdesign table show-summary-程序员宅基地

技术标签: 框架库点滴知识  view ui  

写在前面

金秋十月,iView 4.0 如约而至。但是标题信息量有点大,所以先来解读一下标题。

iView 作者 Aresn 于 2019 年创办了北京视图更新科技有限公司,开始自由、全职地维护 iView 及其相关的软件。View UI 即为原先的 iView,从 2019 年 10 月起正式更名为 View UI,并使用全新的 Logo。iView 作者将在新仓库 github.com/view-design… 继续开发 iView 4.0 和后续版本,以及维护工作。原仓库 iView 作者不再继续提交内容。

简单说就是,我们将 GitHub 迁移到了:

github.com/view-design…

对于绝大部分用户来说,使用没有任何影响,之后的 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 [email protected] --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-methodsum-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 可以通过在输入框中输入文字来创建新的条目。输入新条目后,按下回车键即可新建条目。

 

 

 

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-colorfalse-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 卡片

  • 新增属性 totargetreplaceappend,支持跳转链接。

Tag 标签

  • 新增属性 size,可以设置不同的尺寸,可选值为 large(大号)、medium(中号)、default(默认)

Avatar 头像

  • 尺寸属性 size 支持具体的数值。

Steps 步骤条

  • Step 组件新增具名 slot titlecontenticon
  • Steps 改用 flex 布局,修复最后一列宽度不正确的问题。

其它修复:

  • 修复 Button、Menu 等带有跳转功能组件在 vue-router 3.1+ 版本跳转报错的问题。

不兼容更新

  • DropdownItem 开启 disabled 属性后,Dropdown 不再触发 @on-click 事件。
  • Table 默认样式不再带有外侧边框。

后记

这波更新很给力吧!

iView 已经有 3 年多的沉淀,今天更名为 View UI 也是一个全新的开始。我知道市面上对我们商业化有不同的看法,但 View UI 的初衷是永不变的,会永远免费开源,也会永远更新下去,给大家不断带来期望和惊喜。

但是为了更好的服务企业用户,也为了我的公司得以生存,商业化的产品是在所难免的。如果 View UI 对你的公司或团队节省了成本,提高了开发效率,或者想使用更丰富的高阶组件、强大的整套中、后台前端解决方案,欢迎购买我们的专业版产品 View UI ProAdmin Pro


转载:https://juejin.im/post/5d9d5af0e51d45782e6039cf

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/bbsyi/article/details/102474692

智能推荐

基于水平集的图像分割方法_fcxvsd-程序员宅基地

文章浏览阅读1.2w次,点赞10次,收藏60次。一、引言借鉴一些流体中的重要思想, 1988年,Osher和Sethian首次提出了水平集算法[1],这是一种有效解决曲线演化问题的数值方法,并且计算稳定,适宜任意维数空间。随后,Osher等人对水平集算法做出扩展和总结[2,3], Giga也做了相关的理论扩展[4]。近年来这种算法已被广泛地应用在图像处理领域[5]中 ,尤其在图像分割中已取得了很大的进展。事实上,用水平集来解决图像分割问题的_fcxvsd

php var_export 对循环引用的问题(Uncaught ErrorException: var_export does not handle circular references)-程序员宅基地

文章浏览阅读4.9k次。因为有些数据不知道具体类型,在使用var_export($data, true) 的时候,遇到:Uncaught ErrorException: var_export does not handle circular references。改用: print_r($data, true) 即可解决这个问题。..._var_export does not handle circular references

matlab 生成文件夹,matlab实现遍历文件夹并自动创建对应的新文件夹方法-程序员宅基地

文章浏览阅读789次。能自动将文件夹中所有文件自动的识别并创建对应的文件夹,文件夹名要和文件中某个字段相同。用system()函数。如下tmp1=['mkdir ' dir_final];system(tmp1); %文件夹创建完成我试了下,用下面的函数系统就自动关机了,哈哈fun='shutdown -s';system(fun);你运行了?哈哈,别急赶紧在运行里输入shutdown -a 就取消自动关机了,不过..._natlab nkdir生成文件夹

Android - ImageButton单击切换按钮图片效果的实现_安卓imagebutton加入java-程序员宅基地

文章浏览阅读3.6k次。在android中有一个ImageButton的View,跟Button按钮的区别是可以在Imagebutton上加载一个图片。从ImageButton这个字面意思上来看,它是一个图片按钮,那么我们就可以使用它做一个我们想要的图片按钮了,但是我们在实际使用的过程当中,就会发现该按钮的使用并没有想像中的那么简单,需要再增加一些代码或再配置XML才能实现图片按钮按下的效果,个人感觉有点麻烦,不_安卓imagebutton加入java

IOS 关于NSNotification_nsnotification userinfo 什么类型-程序员宅基地

文章浏览阅读3.4k次。这是一个观察者模式。首先在你需要监听的类中加入观察者:- (void)addObserver:(id)observer selector:(SEL)aSelector name:(NSString *)aName object:(id)anObject;这个观察者在监听到anObject发送名字为aName的notification时,调用selector的方法,在aSelector方_nsnotification userinfo 什么类型

android bundler机制_安卓bundler机制-程序员宅基地

文章浏览阅读2.1k次。在android中提供了一种异步回调机制Handler,使用它,我们可以在完成一个很长时间的任务后做出相应的通知 handler基本使用: 在主线程中,使用handler很简单,new一个Handler对象实现其handleMessage方法,在handleMessage中提供收到消息后相应的处理方法即可,这里不对handler使用进行详细说明,在看本博文前,读者应_安卓bundler机制

随便推点

Cassandra配置多节点集群_cassandra_seeds-程序员宅基地

文章浏览阅读1.5k次。上一篇文章 Cassandra入门指南 中,我们已经配置好了一个单节点集群,接下来,我们要往这个集群中多加几个节点,看看多个节点是如何同时工作的。Cassandra节点之间交换信息是通过一种叫做Gossip(暂时不知道该翻译为哪个专有名词合适,暂且意会吧)的机制。但是要想让一个消息传递到一个新加入的节点,至少还需要知道另外一个节点,这个节点叫做种子(Seed)。通常我们会选择一小部分相对稳定的节点..._cassandra_seeds

python 如何调用子程序并自动传参数 os.system os.popen subprocess_python如何调用子程序-程序员宅基地

文章浏览阅读4.5k次,点赞4次,收藏14次。背景最近工作中有遇到这样一种情况,需要执行一个 exe 文件更改某些设置来触发Service 工作,而执行这个 exe 程序需要一个屏幕输入参数,这个输入参数也是需要python 脚本生成的。如果每次都是 cmd 执行这个 exe 程序,把..._python如何调用子程序

React 中 CSS in JS 的最佳实践_react使用scss-程序员宅基地

文章浏览阅读854次,点赞26次,收藏11次。本人分享一下这次字节跳动、美团、头条等大厂的面试真题涉及到的知识点,以及我个人的学习方法、学习路线等,当然也整理了一些学习文档资料出来是附赠给大家的。知识点涉及比较全面,包括但不限于前端基础,HTML,CSS,JavaScript,Vue,ES6,HTTP,浏览器,算法等等详细大厂面试题答案、学习笔记、学习视频等资料领取,点击资料领取直通车!!全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。**_react使用scss

小程序跳转外链_外链跳转小程序-程序员宅基地

文章浏览阅读2.2k次。小程序跳转外链_外链跳转小程序

微信内置WeixinJSBridge_weixinjsbridge.call-程序员宅基地

文章浏览阅读941次。微信H5页面(关闭页面&&退出网页)isWechat = () => { let ua = window.navigator.userAgent.toLowerCase(); return ua.match(/MicroMessenger/i) == 'micromessenger';};if (isWechat()) { WeixinJSBri..._weixinjsbridge.call

PHP setcookie() 首次存储不上值_首次set-cookie-程序员宅基地

文章浏览阅读888次。客户端:可以看到,浏览器(客户端)向服务器发出一次请求,发出请求的时候,在请求头信息中带上了各种参数,告诉服务器,我要接收什么样的文本(Accept)、什么编码格式(Accept-Encoding)、什么语言(Accept-Language)等等,当然,还把Cookie也传到了服务器(Cookie)。服务器端:第一步:setcookie('a','value')因为cookie是设..._首次set-cookie