element-ui button 源码分享,基于对源码的理解,编写一个简单的 demo,主要分三个模块来分享:
一、button 组件的方法。
1.1 在方法这块,button 组件内部通过暴露 click 方法实现,具体如下:
data:image/s3,"s3://crabby-images/0c601/0c60129b30eef5eee1a2d3e8738455d94c3f4787" alt=""
二、button 组件的计算属性。
2.1 button 组件当中使用的三个计算属性如下:
data:image/s3,"s3://crabby-images/4d76b/4d76b1122cd096bb87206cade4a4bf44e5cefc45" alt=""
三、button 组件的属性。
通过官网我们知道 button 有 size、type、plain、round、circle、loading、disabled、icon、autofocus、native-type 这些属性,那么它是怎么通过传入的这些属性来控制按钮样式的呢?让我们通过对源码的探索来破解它吧。
3.1 size 属性,一般控制按钮的大小,它的尺寸有三种 medium / small / mini,我们可以在源码当中找到这些设置,如下图所示:
data:image/s3,"s3://crabby-images/2acba/2acba516b91716a0813290b7941abfda38c3b3e8" alt=""
3.1.1 通过上图我们知道,真正控制 button 尺寸的并不完全是 size 属性,那么还有什么其他影响因素呢?通过搜索我们在 watch 里面找到了 buttonSize 方法,源码里 buttonSize 方法的返回值来源于三个变量,优先使用所传入的 size 变量,如下图:
data:image/s3,"s3://crabby-images/a7c0f/a7c0f0987dcc28701d0239b878bc311116576522" alt=""
3.1.2 通过对 buttonSize 打印可以看到以下信息,如下图所示:
data:image/s3,"s3://crabby-images/9e423/9e423ca70ac71cfd6da0608d2d394d4f9feab7d3" alt=""
3.1.3 this._elFormItemSize 在哪里可以找到?作用是什么?
data:image/s3,"s3://crabby-images/2a67d/2a67d87662e9170e51fd122f8e8ec9c1edab1eed" alt=""
data:image/s3,"s3://crabby-images/c7d3a/c7d3a8a550d9e9242b63d17d11944ba3ebaf3148" alt=""
data:image/s3,"s3://crabby-images/76a85/76a85dcd44043ac2f545504b094a2c1adfac5db3" alt=""
data:image/s3,"s3://crabby-images/149cd/149cdce8f6c0ae4009a461de0cdd1cac339160f8" alt=""
3.1.4 上面说了一堆,有人可能会迷惑,找这些东西干什么用呢?又能证明什么呢?莫慌,多一丢丢儿耐心往下看哈。
data:image/s3,"s3://crabby-images/0fa31/0fa31dd0ac510725a82d87d950a55d6c6e18a5b7" alt=""
data:image/s3,"s3://crabby-images/81bcf/81bcf36120f0d2dd125d9f4c3ef7a2d835af65e3" alt=""
3.1.5 this.$ELEMENT 这个是全局的变量,在 /examples/entry.js 文件中进行全局设置
data:image/s3,"s3://crabby-images/796ea/796ea059a659300ffca1a1300cb062fd18abf4e9" alt=""
data:image/s3,"s3://crabby-images/83cf0/83cf00379e773b51eefee98baa5e25a331885852" alt=""
3.1.6 简单总结一下 button 按钮 size 属性:
- button 按钮的 size 若传则取所传的值
- button 按钮的 size 未传且不在 form 表单中,默认取 middle
- button 按钮的 size 为传且在 form 表单中,且 form 表单有设置 size,这取 form 表单的 size
- button 按钮的 size 未传且不在 form 表单中,但设置了全局变量 $ELEMENT.size,则取全局变量中的 size
3.2 type 属性,控制按钮的样式,类型有 primary / success / warning / danger / info / text
3.2.1 通过传入 type 值,样式表中有之对应的样式,如下图:
data:image/s3,"s3://crabby-images/26a1f/26a1f38afc2159b981d34b3c5cdafd8ef6dfcac6" alt=""
data:image/s3,"s3://crabby-images/9de7b/9de7b1d98a6d470457efc9d522731cf7135fc273" alt=""
data:image/s3,"s3://crabby-images/fd155/fd15545b248399a1ffca226db8624f8ff8376d32" alt=""
上面的样式翻译过来大致是这样的:
css
.el-button--primary:first-child {
border-right-color: rgba($--color-white, 0.5);
}
.el-button--primary:last-child {
border-left-color: rgba($--color-white, 0.5);
}
.el-button--primary:not(:first-child):not(:last-child) {
border-left-color: rgba($--color-white, 0.5);
border-right-color: rgba($--color-white, 0.5);
}
.el-button--success:first-child {
border-right-color: rgba($--color-white, 0.5);
}
.el-button--success:last-child {
border-left-color: rgba($--color-white, 0.5);
}
.el-button--success:not(:first-child):not(:last-child) {
border-left-color: rgba($--color-white, 0.5);
border-right-color: rgba($--color-white, 0.5);
}
.el-button--warning:first-child {
border-right-color: rgba($--color-white, 0.5);
}
.el-button--warning:last-child {
border-left-color: rgba($--color-white, 0.5);
}
.el-button--warning:not(:first-child):not(:last-child) {
border-left-color: rgba($--color-white, 0.5);
border-right-color: rgba($--color-white, 0.5);
}
.el-button--danger:first-child {
border-right-color: rgba($--color-white, 0.5);
}
.el-button--danger:last-child {
border-left-color: rgba($--color-white, 0.5);
}
.el-button--danger:not(:first-child):not(:last-child) {
border-left-color: rgba($--color-white, 0.5);
border-right-color: rgba($--color-white, 0.5);
}
.el-button--info:first-child {
border-right-color: rgba($--color-white, 0.5);
}
.el-button--info:last-child {
border-left-color: rgba($--color-white, 0.5);
}
.el-button--info:not(:first-child):not(:last-child) {
border-left-color: rgba($--color-white, 0.5);
border-right-color: rgba($--color-white, 0.5);
}
3.2.2 plain 属性,是否朴素按钮,布尔类型,默认 false
data:image/s3,"s3://crabby-images/2553a/2553a064ec8ccb7daa7fa251505ec2633436d905" alt=""
data:image/s3,"s3://crabby-images/b1307/b13072450b1b3215c4026fe5c98631a0454dfa98" alt=""
data:image/s3,"s3://crabby-images/539a5/539a5699312f21dd1cb0c8970a87b121f8a68921" alt=""
上面的样式翻译过来大致是这样的:
css
.is-plain,
.is-plain:hover,
.is-plain:focus {
background-color: $--color-white;
border-color: $--button-disabled-border-color;
color: $--button-disabled-font-color;
}
3.2.3 round 属性,是否圆角按钮,布尔类型,默认 false
data:image/s3,"s3://crabby-images/5d810/5d810dceb7ad00b04598d7a39fd5e12db887159d" alt=""
data:image/s3,"s3://crabby-images/b22ed/b22ed8e9d43a4fb8d7e72e89b33633777376ddc2" alt=""
data:image/s3,"s3://crabby-images/27ceb/27cebf505b93a9bb3687dfee4ca3b0ffbc1bc0c1" alt=""
3.2.4 circle 属性,是否圆形按钮,布尔类型,默认 false
data:image/s3,"s3://crabby-images/0a4da/0a4dad805de574a338cb5298b90e4f6fd3254cf8" alt=""
data:image/s3,"s3://crabby-images/2da43/2da4322957538ee1f6131bae4c7e02716a700346" alt=""
data:image/s3,"s3://crabby-images/58a77/58a77219af18df5f159cd701ffa1d37642b66c8c" alt=""
3.2.5 loading 属性,是否加载中状态,布尔类型,默认 false
data:image/s3,"s3://crabby-images/7e71b/7e71b12d783394844d68a1ec60be84accb0ebf05" alt=""
data:image/s3,"s3://crabby-images/4f980/4f980152a11ee76f0751b59007a082b026f68039" alt=""
data:image/s3,"s3://crabby-images/95331/953319229b1ded7f5cd9554726037d03fe2a06de" alt=""
注意:如果使用了自定义图标 icon,可以使用 element-ui icon 组件里面有的图标,也可以自定义一个图标,其实在这里传的 icon 就是 class(通过上面的图很容易看出)。
3.2.6 disabled 属性,是否禁用状态,布尔类型,默认 false
data:image/s3,"s3://crabby-images/ddb1c/ddb1c0097a6685e1ebd5d64088a4b566579e9b45" alt=""
data:image/s3,"s3://crabby-images/ce887/ce887ac34d8e19a624d2cd7f06eceec1254e4e31" alt=""
补充说明(buttonDisabled):
tip1:在 Vue 2 中,this.$options
是一个对象,它包含了组件的初始化选项。这些选项是组件定义时通过 option
属性传入的。通过 this.$options
,你可以访问到组件的配置信息,包括生命周期钩子函数、自定义方法、属性等。
tip2:Vue2的 propsData 主要用于在组件初始化时传递数据。propsData 选项是一个对象,其中包含了要传递给组件的属性值。这些属性值可以在组件的data函数中被访问和使用。
data:image/s3,"s3://crabby-images/e2043/e2043e967294104d90b1611f66fd0757d3a376a9" alt=""
data:image/s3,"s3://crabby-images/3c97e/3c97e656e1afb105615033e2c6bbce5e3a9f64d8" alt=""
上面的样式翻译过来大致是这样的:
css
.disabled,
.disabled:hover,
.disabled:focus {
color: $--button-disabled-font-color;
cursor: not-allowed;
background-image: none;
background-color: $--button-disabled-background-color;
border-color: $--button-disabled-border-color;
}
.el-button--text.disabled {
background-color: transparent;
}
.is-plain.disabled,
.is-plain.disabled:hover,
.is-plain.disabled:focus {
background-color: $--color-white;
border-color: $--button-disabled-border-color;
color: $--button-disabled-font-color;
}
3.2.7 disabled 属性,图标类名,string 类型,默认""
data:image/s3,"s3://crabby-images/91a88/91a88c025638603a2ef2567aab1a55cb83eef8a4" alt=""
data:image/s3,"s3://crabby-images/c4000/c40005386a296ec2188e270b753a41cea779c767" alt=""
data:image/s3,"s3://crabby-images/f3186/f318697823accb9b42b7356e96798a78a9adec1d" alt=""
3.2.8 autofocus 属性,是否默认聚焦,布尔类型,默认 flase
data:image/s3,"s3://crabby-images/52daa/52daad761e4059d6c45eaf8ea09588addb074e17" alt=""
data:image/s3,"s3://crabby-images/36599/36599748e56baeb3bb41f0ed51d7c5cb04548fc4" alt=""
data:image/s3,"s3://crabby-images/63e87/63e873d3898b0dcbea7deeaeb22c6101c4fd89c4" alt=""
3.2.9 native-type 属性,原生 type 属性,string 类型,button / submit / reset,默认 button
data:image/s3,"s3://crabby-images/42491/4249102024bcef6614c848d69134bf8e18689317" alt=""
data:image/s3,"s3://crabby-images/7fe23/7fe23f79ff3a5e55b8ff1c13425beecd35f4a19d" alt=""
3.2.9 button slot 卡槽分发:
data:image/s3,"s3://crabby-images/63f86/63f862cbe6471581ccbea1261aa4499d3957393e" alt=""
举个栗子:
data:image/s3,"s3://crabby-images/fc6d0/fc6d035eacd34c715b2579eff11a3a3c24d54f77" alt=""
data:image/s3,"s3://crabby-images/f55b8/f55b860407a2df35cc612d578b79fb6d22a3de37" alt=""
总结:
看似简单的 button 按钮,看完源码后会发现里面会有很多值得我们去学习去思考的知识,因此希望可以一直保持好奇心,将剩下的组件一并研究明白并分享出来。
关于 button 按钮的源码分享部分就先到这里了,由于篇幅比较长,这里就不再做基于源码后的 demo 分享了,有时间下次专门写一篇关于基于源码理解后的 button demo 分享。