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

网站建设运营的灵魂是上海自助建站官网

网站建设运营的灵魂是,上海自助建站官网,东莞建设网住房保障,宜昌网站开发公司封装UI组件库系列第四篇封装Button按钮组件 #x1f31f;前言 #x1f31f;封装Button组件 1.分析封装组件所需支持的属性与事件 支持的属性#xff1a; 支持的事件#xff1a; 2.创建Button组件 #x1f31f;封装功能属性 type主题颜色 plain是否朴素 loading等… 封装UI组件库系列第四篇·封装Button按钮组件 前言 封装Button组件 1.分析封装组件所需支持的属性与事件 支持的属性 支持的事件 2.创建Button组件 封装功能属性 type主题颜色 plain是否朴素 loading等待状态 其他属性  总结 前言 在前端开发中大家可能已经用过各种各样的UI组件库了现在市面上热门的有Element-ui、Ant Design等等这些即插即用的组件库确实大大提升了开发效率避免了很多的重复劳动但这些组件库再怎么完善又怎么能满足得了我们可爱的产品经理呢所以工作中难免会需要开发公司内部的UI组件库或者基于已有组件库进行二开。 【封装UI组件库系列】文章将从0开始--》搭建项目--》封装八大经典功能组件--》打包组件库--》将组件库发布至npm--》使用自己封装的组件库。技术方面使用的是Vue3 Vite Sass 来完成一个模仿Element Plus的组件库。最终完成效果如下 【封装UI组件库系列】建议从开篇开始阅读https://blog.csdn.net/g_ing/category_12503768.html?spm1001.2014.3001.5482 封装Button组件 上一篇我们已经封装了第一个Icon组件接下来我们就开始封装Button组件 1.分析封装组件所需支持的属性与事件 在开始敲代码前我们需要先有个思路要开发什么需要什么功能先定好再动手 支持的属性 属性名作用类型是否必须默认值type主题颜色String否defaultsize大小String否无plain是否朴素Boolean否falseround是否圆角Boolean否falsecircle是否圆形Boolean否falsedisabled是否禁用Boolean否falseloading是否加载中Boolean否falseicon图标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 templatebutton ref_ref classvisual-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 iconspinner spin v-ifloading /Visual-Icon :iconicon v-ificon /span v-if$slots.defaultslot //span/button /templatescript setupimport propObj from ./propsdefineOptions({name: visual-Button})defineProps(propObj) /script style langscss 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://wiki.neutronadmin.com/news/393903/

相关文章:

  • ui作品集 网站怎么做世界500强设计公司有哪些
  • 建筑门户网站老鹰主机 wordpress
  • 沈阳网站专业西安搜建站科技网站
  • 个人想做企业网站备案淮安 做网站 app
  • 肥乡企业做网站推广百度推广手机网站检测
  • 免费推广网站哪家好如何访问自己做的网站
  • 广州网站公司建设网站天津网站建设的公司哪家好
  • 永州网站建设包括哪些网站开发之美
  • 网站建设个一般需要花费多少钱一键开启网站
  • 网站开发语言开发汕头网站开发
  • 江苏城乡与住房建设部网站网站建站在线制作
  • 网站设计报价方案上海礼品定制网站
  • 途牛网站大数据建设手机网站开发软件下载
  • 数据做图网站网站开发兼容问题
  • 怎么做二次元网站源码加快百度收录的方法
  • 常平建设局网站网络广告策划
  • 网站建设属于网络还是软件网站建设开淘宝直通车
  • 网站建设 招聘网站建设最简单的教程视频
  • 专做国外旅游的网站专业做网站 郑州
  • p2p网贷网站建设方案wordpress 导入工具插件
  • 网站建设网站制作网站设计园林景观设计公司需要什么资质
  • 英文网站建设方案模板高校seo网络推广软件
  • wordpress 图片分享主题廊坊首页霸屏优化
  • 品牌网站建设技术公众号 接入wordpress
  • 深圳 微网站建设ydgcm德阳企业品牌网站建设
  • 怎么使用模板建设网站分类达人介绍
  • 宁夏银川网站建设如何做wordpress文章页
  • 无为网站定制免费网站从哪里申请
  • 一级a做爰片视频免费观看网站h5免费制作平台哪个好
  • 免费设计室内装修软件网站东莞优化建设