vue3基础组件开发-Checkbox(多选框组件)

前言

使用了vue3有很长一段时间了,写了很多的基础组件在自己使用,整理一下(尽量使用最简单的方式实现),当做对自己知识的梳理。

tips: 可能是最简单的checkBox组件

技术栈

vue3 + tailwindcss + ts + vite

页面开发

html 复制代码
<label> 
    <input type="checkbox" checked> 这是一个多选框
</label>

进一步优化

多选框组件,最重要的就是改变多选框的颜色,以前要用一些特殊的方法,现在只需一行代码搞定

html 复制代码
<label> 
    <input type="checkbox" checked class="accent-pink-500"> 这是一个多选框
</label>

原理如下:

accent-color ,一个css新的属性(嗯,可能也不是很新,出来蛮久了)

兼容如下:

如果是做electron开发,且不需要兼容windows7,可以大胆用了

降级处理方案

so,如果说,老版本的浏览器,不兼容怎么办么。

不用担心,还有另外的方案,代码如下:

html 复制代码
<div
  class="h-4 w-4 rounded border relative"
  :class="{ 'border-[#FF9B27]': checkCreateCommunity }"
>
  <input
    v-model="checkCreateCommunity"
    type="checkbox"
    class="w-full h-full appearance-none absolute top-0 left-0 checked:before:scale-[0.8] checked:bg-[#FF9B27] checked:before:content-['\e6b8'] checked:before:text-white checked:before:font-['iconfont'] checked:before:absolute checked:before:-top-[5px] checked:before:-left-[1px] cursor-pointer"
  />
</div>

降级方案原理解析

  • 1、两层dom元素,外层的div控制多选框大小、圆角、边框等,里面的input实现对勾。
  • 2、v-model指令将checkCreateCommunity与复选框的值进行双向绑定,同步更新外层div的边框选中颜色
  • 3、appearance-none 移除浏览器默认的复选框样式
  • 4、absolutetop-0left-0用于将复选框相对于父容器进行绝对定位
  • 5、checked:before:scale-[0.8]用于将伪元素缩放为原始尺寸的0.8倍
  • 6、checked:bg-[#FF9B27]用于设置选中状态下的背景颜色
  • 7、checked:before:content-['\e6b8']用于设置伪元素的内容为Unicode码\e6b8对应的字符

so,一句话原理就是:这个多选框组件根据checkCreateCommunity属性的值,可以控制复选框的选中状态和外观样式。选中状态下,复选框会显示特定的边框颜色、缩小的图标、橙色背景和白色文字。未选中状态下,复选框没有特殊的样式

尾声

妈妈再也不用担心不会写Checkbox了,水平有限,如有错漏之处,欢迎大佬指正

相关推荐
Cobyte3 小时前
15.响应式系统比对:链表在 Preact Signals 响应式系统中的应用
前端·javascript·vue.js
摇滚侠3 小时前
浏览器调试工具 检查元素 谷歌模拟器 控制台 断点调试
java·html
yivifu3 小时前
CSS 自动级联编号有序列表完全指南
前端·css·c#·html·有序列表·级联编号
jay神3 小时前
基于 Python + Flask + Vue 的校内求职互助平台
前端·vue.js·后端·python·flask·毕业设计
ThinkPet4 小时前
记事-vue3项目整合Agora声网sdk实现RTC视频通话
vue.js·音视频·实时音视频
daols884 小时前
vxe-table 进阶:同时使用 formatter 与 cell-render 实现格式化与样式定制
前端·javascript·vue.js·vxe-table
用户059540174464 小时前
用LangChain+FastAPI构建私有知识库踩坑实录:这3个问题让我排查了整整8小时
前端·css
Momo__4 小时前
CSS View Transitions 新语法:sibling-index() + ident(),千级元素命名难题的终局方案
前端·css
前端张三4 小时前
ant design vue table 使用虚拟滚动
前端·javascript·vue.js
孟陬5 小时前
首次上榜新项目 HyperFrames(22k Star):HTML → MP4 一句话生成视频
react.js·node.js·html