Vue2封装自制组件(二):按钮组件

Vue组件的API分为几部分:model,props,slot,event,$emit

在这里button只需要用到props单向传送即可。

一:button.vue组件代码

<template>
	<button class="vi-button" @click="handleClick"
		:class="[type ? 'vi-button--' + type : '',size ? 'vi-button--' + size:'']">
		<slot></slot>
	</button>
</template>
<script>
	export default {
		name: 'ViButton',
		componentName: 'ViButton',
		props: {
			type: {
				type: String,
				default: 'default'//组件默认样式
			},
			size: String,//组件大小
		},
		methods: {
			handleClick(evt) {//点击反馈
				this.$emit('click', evt);
			}
		}
	};
</script>

这里定义了type和size两个参数,可以控制按钮样式和大小。

同样,也可以灵活修改,比如按钮标题的位置,可以新加一个label参数来修改。

二:index.css中加入按钮样式

.vi-button {
	display: inline-block;
	padding: 8px 20px;
	outline: 0;
	text-align: center;
	white-space: nowrap;
	border: 1px solid #c5d9e8;
	border-radius: 10px;
	background-color: #fff;
	-webkit-transition: background .2s;
	transition: background .2s;
	-webkit-user-sviect: none;
	-moz-user-sviect: none;
	-ms-user-sviect: none;
	user-sviect: none;
	cursor: pointer;
	font-size: 12px;
	overflow: hidden;
	color: #324A5D;
}

.vi-button:hover {
	background-color: #f3f7fa
}

.vi-button--primary {
	color: #FFF;
	border: none;
	background-color: #324A5D;
	border-color: #324A5D;
}

.vi-button--primary:hover {
	background: #5B6E7D;
	border-color: #5B6E7D;
}

.vi-button--mini {
	padding: 4px 20px;
}

.vi-button--small {
	padding: 6px 20px;
}

.vi-button--medium {
	padding: 10px 20px;
}

css样式中可以随意更改按钮颜色和按钮大小,灵活改动。

同时,也可以加入按钮禁用样式。

三:按钮禁用

button.vue

<template>
	<button class="vi-button" @click="handleClick"
		:class="[type ? 'vi-button--' + type : '',size ? 'vi-button--' + size:'',{'is-disabled': disabled}]"
		:disabled="disabled">
		<slot></slot>
	</button>
</template>
<script>
	export default {
		name: 'ViButton',
		componentName: 'ViButton',
		props: {
			type: {
				type: String,
				default: 'default'
			},
			size: String,
			disabled: {
				type: Boolean,
				default: false,
			},
		},
		methods: {
			handleClick(evt) {
				this.$emit('click', evt);
			}
		}
	};
</script>

index.css

//禁用按钮
.vi-button.is-disabled {
	background-color: #FAFAFA;
	cursor: not-allowed;
}

四:按钮组件使用示例

<vi-button>默认按钮</vi-button>
<vi-button type="primary">主要按钮</vi-button>
<vi-button size="medium">大型按钮</vi-button>
<vi-button size="small">小型按钮</vi-button>
<vi-button size="mini">迷你按钮</vi-button>
<vi-button disabled>禁用按钮</vi-button>

效果:

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

悍司命

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值