当前位置: 首页 > news >正文

服务器托管和租用区别aso关键词优化计划

服务器托管和租用区别,aso关键词优化计划,小男生和大人做的网站,网站建设需要用到的技术封装UI组件库系列第四篇封装Button按钮组件 🌟前言 🌟封装Button组件 1.分析封装组件所需支持的属性与事件 支持的属性: 支持的事件: 2.创建Button组件 🌟封装功能属性 type主题颜色 plain是否朴素 loading等…

封装UI组件库系列第四篇·封装Button按钮组件

🌟前言

🌟封装Button组件

1.分析封装组件所需支持的属性与事件

支持的属性:

支持的事件:

2.创建Button组件

🌟封装功能属性

type主题颜色

plain是否朴素

loading等待状态

其他属性 

 🌟总结


🌟前言

在前端开发中,大家可能已经用过各种各样的UI组件库了,现在市面上热门的有Element-uiAnt Design等等,这些即插即用的组件库确实大大提升了开发效率,避免了很多的重复劳动,但这些组件库再怎么完善,又怎么能满足得了我们可爱的产品经理呢?所以工作中难免会需要开发公司内部的UI组件库,或者基于已有组件库进行二开。

【封装UI组件库系列】文章,将从0开始--》搭建项目--》封装八大经典功能组件--》打包组件库--》将组件库发布至npm--》使用自己封装的组件库。技术方面使用的是Vue3 + Vite + Sass 来完成一个模仿Element Plus的组件库。最终完成效果如下:

【封装UI组件库系列】建议从开篇开始阅读!!!icon-default.png?t=N7T8https://blog.csdn.net/g_ing/category_12503768.html?spm=1001.2014.3001.5482

🌟封装Button组件

上一篇我们已经封装了第一个Icon组件,接下来我们就开始封装Button组件

1.分析封装组件所需支持的属性与事件

在开始敲代码前,我们需要先有个思路,要开发什么,需要什么功能,先定好,再动手:

支持的属性:

属性名作用类型是否必须默认值
type主题颜色Stringdefault
size大小String
plain是否朴素Booleanfalse
round是否圆角Booleanfalse
circle是否圆形Booleanfalse
disabled是否禁用Booleanfalse
loading是否加载中Booleanfalse
icon图标String

支持的事件:

事件名作用
click点击事件

 确定好要做的事情,就可以开干喽。

2.创建Button组件

创建组件Button.vue:

 在main.js中引入注册:

在views/Button.vue中使用:

🌟封装功能属性

老规矩,新建src/components/Button/props.js  文件义属性:

type主题颜色

props.js:

export default {type: {type: String,default: 'default'},
}

新建style/components/icon.scss 

完善基本样式,其实这里很多用到的就是第二篇文章中定义的样式(具体代码文末):

接下来就是实现主题颜色:

 前面文章也将过的,这里还是使用scss语法:

 然后在组件中去判断有没有type,有的话就挂上对应样式类:

效果如下: 

plain是否朴素

同理,定义样式:

定义props: 

判断条件:

loading等待状态

这里需要用到上节课封装的Icon组件:

 使用:

效果:

其他属性 

讲过上面几种后其他的大差不差,直接上代码

/components/Button/Button.vue:

<template><button ref="_ref" class="visual-button" :class="{[`visual-button--${type}`]: type,[`visual-button--${size}`]: size,'is-plain': plain,'is-round': round,'is-circle': circle,'is-disabled': disabled || loading}"><Visual-Icon icon="spinner" spin v-if="loading" /><Visual-Icon :icon="icon" v-if="icon" /><span v-if="$slots.default"><slot /></span></button>
</template><script setup>import propObj from './props'defineOptions({name: 'visual-Button'})defineProps(propObj)
</script>
<style lang="scss" scoped></style>

 /components/Button/props.js:

export default {type: {type: String,default: 'default'},plain: {type: Boolean,default: false},round: {type: Boolean,default: false},disabled: {type: Boolean,default: false},loading: {type: Boolean,default: false},icon: {type: String},size: {type: String},circle: {type: Boolean,default: false}
}

styles/components/button.scss:

// 首先针对这个样式类里面,定义了一系列的样式变量
.visual-button {--visual-button-font-weight: var(--visual-font-weight-primary);--visual-button-border-color: var(--visual-border-color);--visual-button-bg-color: var(--visual-fill-color-blank);--visual-button-text-color: var(--visual-text-color-regular);--visual-button-disabled-text-color: var(--visual-disabled-text-color);--visual-button-disabled-bg-color: var(--visual-fill-color-blank);--visual-button-disabled-border-color: var(--visual-border-color-light);--visual-button-hover-text-color: var(--visual-color-primary);--visual-button-hover-bg-color: var(--visual-color-primary-light-9);--visual-button-hover-border-color: var(--visual-color-primary-light-7);--visual-button-active-text-color: var(--visual-button-hover-text-color);--visual-button-active-border-color: var(--visual-color-primary);--visual-button-active-bg-color: var(--visual-button-hover-bg-color);--visual-button-outline-color: var(--visual-color-primary-light-5);--visual-button-active-color: var(--visual-text-color-primary);
}.visual-button {// 接下来再来书写基本的样式display: inline-block;line-height: 1;white-space: nowrap;cursor: pointer;height: 40px;background-color: var(--visual-button-bg-color);border: var(--visual-border);border-color: var(--visual-button-border-color);color: var(--visual-button-text-color);appearance: none;text-align: center;box-sizing: border-box;outline: none;margin: 0;transition: 0.1s;font-weight: var(--visual-button-font-weight);user-select: none;vertical-align: middle;padding: 12px 20px;font-size: var(--visual-font-size-base);border-radius: var(--visual-border-radius-base);&:hover,&:focus {color: var(--visual-button-hover-text-color);border-color: var(--visual-button-hover-border-color);background-color: var(--visual-button-hover-bg-color);outline: none;}&:active {color: var(--visual-button-active-text-color);border-color: var(--visual-button-active-border-color);background-color: var(--visual-button-active-bg-color);outline: none;}&.is-round {border-radius: var(--visual-border-radius-round);}&.is-circle {width: 45px;height: 45px;border-radius: 50%;padding: 12px;display: flex;justify-content: center;align-items: center;}// 禁用相关的样式&.is-disabled,&.is-disabled:hover,&.is-disabled:focus,&[disabled],&[disabled]:hover,&[disabled]:focus {color: var(--visual-button-disabled-text-color);cursor: not-allowed;background-image: none;background-color: var(--visual-button-disabled-bg-color);border-color: var(--visual-button-disabled-border-color);}[class*='visual-icon'] + span {margin-left: 6px;position: relative;bottom: 2px;}
}@each $val in primary, success, warning, info, danger {// 这是一种非常灵活的方式,通过挂上去一些类,改变 CSS 变量所对应的值.visual-button--#{$val} {--visual-button-text-color: var(--visual-color-white);--visual-button-bg-color: var(--visual-color-#{$val});--visual-button-border-color: var(--visual-color-#{$val});--visual-button-outline-color: var(--visual-color-#{$val}-light-5);--visual-button-active-color: var(--visual-color-#{$val}-dark-2);--visual-button-hover-text-color: var(--visual-color-white);--visual-button-hover-bg-color: var(--visual-color-#{$val}-light-3);--visual-button-hover-border-color: var(--visual-color-#{$val}-light-3);--visual-button-active-bg-color: var(--visual-color-#{$val}-dark-2);--visual-button-active-border-color: var(--visual-color-#{$val}-dark-2);--visual-button-disabled-text-color: var(--visual-color-white);--visual-button-disabled-bg-color: var(--visual-color-#{$val}-light-5);--visual-button-disabled-border-color: var(--visual-color-#{$val}-light-5);}// 如果挂了 is-plain 这个,那么同样是改变一些 CSS 变量的值.visual-button--#{$val}.is-plain {--visual-button-text-color: var(--visual-color-#{$val});--visual-button-bg-color: var(--visual-color-#{$val}-light-9);--visual-button-border-color: var(--visual-color-#{$val}-light-5);--visual-button-hover-text-color: var(--visual-color-white);--visual-button-hover-bg-color: var(--visual-color-#{$val});--visual-button-hover-border-color: var(--visual-color-#{$val});--visual-button-active-text-color: var(--visual-color-white);}
}// 针对 visual-button-large 以及 visual-button-small 书写相应的样式即可
.visual-button--large {--visual-button-size: 50px;height: var(--visual-button-size);padding: 12px 19px;font-size: var(--visual-font-size-base);border-radius: var(--visual-border-radius-base);
}
.visual-button--small {--visual-button-size: 24px;height: var(--visual-button-size);padding: 5px 11px;font-size: 12px;border-radius: calc(var(--visual-border-radius-base) - 1px);
}

 🌟总结

 【封装UI组件库系列】文章会持续更新,将带着大家从0开始--》搭建项目--》封装八大经典功能组件--》打包组件库--》将组件库发布至npm--》最后使用自己封装的组件库。如果文中出现有瑕疵的地方各位通过评论或者私信联系我,我们一起进步!该系列文章建议从第一篇开始看,系列专栏地址:从零开始封装UI组件库完整篇


文章转载自:
http://dinncolokanta.bkqw.cn
http://dinncoamiantus.bkqw.cn
http://dinncoduodena.bkqw.cn
http://dinncocollagenase.bkqw.cn
http://dinncosyllabary.bkqw.cn
http://dinncoseedpod.bkqw.cn
http://dinncoaerogramme.bkqw.cn
http://dinncodenervate.bkqw.cn
http://dinncokilometre.bkqw.cn
http://dinncochristlike.bkqw.cn
http://dinncowhy.bkqw.cn
http://dinncobiauriculate.bkqw.cn
http://dinncograteful.bkqw.cn
http://dinncorestiveness.bkqw.cn
http://dinncorubify.bkqw.cn
http://dinncouintahite.bkqw.cn
http://dinncosandalwood.bkqw.cn
http://dinncoqualmish.bkqw.cn
http://dinncocomitiva.bkqw.cn
http://dinncosulpharsphenamine.bkqw.cn
http://dinncoduckfooted.bkqw.cn
http://dinncoactable.bkqw.cn
http://dinncoseptavalent.bkqw.cn
http://dinncoovertrain.bkqw.cn
http://dinncopolyphage.bkqw.cn
http://dinncounserviceable.bkqw.cn
http://dinncosyncromesh.bkqw.cn
http://dinncorefrangible.bkqw.cn
http://dinncorodingitize.bkqw.cn
http://dinncoepitaxial.bkqw.cn
http://dinncocerated.bkqw.cn
http://dinncoempocket.bkqw.cn
http://dinncobloodguilty.bkqw.cn
http://dinncotimocracy.bkqw.cn
http://dinncoretardance.bkqw.cn
http://dinncorecolonization.bkqw.cn
http://dinncotrendy.bkqw.cn
http://dinncocompatibility.bkqw.cn
http://dinncoautogestion.bkqw.cn
http://dinncostraitjacket.bkqw.cn
http://dinncotwybill.bkqw.cn
http://dinncochindwin.bkqw.cn
http://dinncodialyzate.bkqw.cn
http://dinncoringingly.bkqw.cn
http://dinncoecthlipses.bkqw.cn
http://dinncoretrospect.bkqw.cn
http://dinncohallucinosis.bkqw.cn
http://dinncodoorjamb.bkqw.cn
http://dinncoclanger.bkqw.cn
http://dinncopcweek.bkqw.cn
http://dinncoloudmouth.bkqw.cn
http://dinncorevokable.bkqw.cn
http://dinncoattentat.bkqw.cn
http://dinncostopgap.bkqw.cn
http://dinncoviviparous.bkqw.cn
http://dinncogramarye.bkqw.cn
http://dinncomedallic.bkqw.cn
http://dinncosemiworks.bkqw.cn
http://dinncoconfraternity.bkqw.cn
http://dinncoinconsumable.bkqw.cn
http://dinncohighbinder.bkqw.cn
http://dinncoreconvert.bkqw.cn
http://dinncowashingtonian.bkqw.cn
http://dinncohomozygosis.bkqw.cn
http://dinncokyoto.bkqw.cn
http://dinncogloriette.bkqw.cn
http://dinncopresumable.bkqw.cn
http://dinncoimperialistic.bkqw.cn
http://dinncolamp.bkqw.cn
http://dinncotrailing.bkqw.cn
http://dinncofever.bkqw.cn
http://dinncophosphatidylethanolamine.bkqw.cn
http://dinncotintinnabular.bkqw.cn
http://dinncodibatag.bkqw.cn
http://dinncofucking.bkqw.cn
http://dinncoresonator.bkqw.cn
http://dinncoterrella.bkqw.cn
http://dinncodecompress.bkqw.cn
http://dinncothyrse.bkqw.cn
http://dinncowrathful.bkqw.cn
http://dinncoreable.bkqw.cn
http://dinncoorthoclase.bkqw.cn
http://dinncospindleage.bkqw.cn
http://dinncorabidity.bkqw.cn
http://dinncotoken.bkqw.cn
http://dinncohellhound.bkqw.cn
http://dinncohobo.bkqw.cn
http://dinncontsc.bkqw.cn
http://dinnconosocomial.bkqw.cn
http://dinncomultipole.bkqw.cn
http://dinncoprotopodite.bkqw.cn
http://dinncohotheaded.bkqw.cn
http://dinncolaurustine.bkqw.cn
http://dinncosulfid.bkqw.cn
http://dinncoxylotile.bkqw.cn
http://dinncohemoptysis.bkqw.cn
http://dinncocrocodile.bkqw.cn
http://dinncoglucosuria.bkqw.cn
http://dinncoafterdamp.bkqw.cn
http://dinncodetribalize.bkqw.cn
http://www.dinnco.com/news/137652.html

相关文章:

  • 网站策划书的撰写百度推广手机登录
  • 济宁建设信息网官网东莞seo网站优化排名
  • 网站开发文献综述范文百度账户登录
  • 做企业网站需要的人seo是什么
  • 网站图片用什么做爱客crm
  • 南昌百度推广联系方式seo网站介绍
  • 注册网站卖钱最多的人百度推广费用一天多少钱
  • 做网站上传视频电脑优化设置
  • 网站建设网站制作公司seo网站培训
  • 病毒式营销的特点网站关键词优化软件
  • 济宁亿蜂网站建设怎么开网店新手入门
  • 国外单页制作网站模板下载常见的网络营销工具
  • 网站推广广告申请外链网盘源码
  • wordpress做企业网站网上推广渠道有哪些
  • 05网寒假作业深圳网站营销seo电话
  • 绵阳网站制作微博seo营销
  • 如何设计网站风格个人如何优化网站有哪些方法
  • 南阳做网站的公建站合肥网络公司seo
  • 常州网站建设费用seo行业岗位
  • 坪山网站建设资讯开鲁网站seo免费版
  • 武汉教育网站建设优化seo自学教程推荐
  • 电商网站推广常见问题百度知道怎么赚钱
  • 网站不能批量上传图片营销咨询师
  • 建设执业资格管理中心网站百度网盟广告
  • 图片分页网站模板手机优化游戏性能的软件
  • 做一个交友网站怎样做需要多少资金沧州百度推广总代理
  • 太原网站建设价格低东莞网络公司电话
  • 盱眙在仕德伟做网站的有几家个人网站设计模板
  • 静态网站的好处广州白云区新闻头条最新消息今天
  • 河南国基建设集团有限公司网站淘宝怎么优化关键词排名