百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

实现一个超有趣的 Material-UI 风格 Input 框

zhezhongyun 2024-12-25 16:47 76 浏览

最近看到一个组件库叫做 Material-UI,它里面有一个 Input 框的效果非常有意思,效果如下

所以想自己实现一遍,并分享给大家~

基础组件代码

这个效果有两个动画点:

  • 1、提示文本移动到上分
  • 2、下方滑动条

提示文本可以使用绝对定位,将它移动到 input 的上方,并且要跟 input 的 placeholder水平一致

可以先设置 input 的 placeholder,然后慢慢调整 top 定位,直到水平对齐,再去掉 placeholder

至于滑动条,直接放置在容器底部即可~

现在可以得到基础的组件效果

动画效果

两个动画效果:

  • 1、提示文本移动到上分
  • 2、下方滑动条

这两个动画效果的触发时机都是:input 框聚焦的时候

所以需要监听 input 的聚焦事件,去触发动画效果,第一个动画效果改动的是top: 1px -> -30px、left: 5px -> 0px,第二个动画效果改动的是width: 0 -> 100%

所以我们需要给这两个节点样式先设置对应样式的 transition

设置好transition就要开始去触发动画效果了,需要监听 input 的聚焦事件

注意:失焦时需要恢复默认样式

现在就能达到我们想要的动画效果了~

检测 Input 的值

有一个小优化点就是,当 input 框有值的时候,提示文本不应该恢复原状,不然就会导致重叠效果,如下

只需要在失焦的时候判断拦截一下即可

最终效果 & 完整代码

<template>
    <label class="input-container">
      <div ref="label" class="label">Enter Your Username</div>
      <input class="input" v-model="value"  @focus="onFocus" @blur="onBlur"></input>
      <div class="line" ref="line"></div>
    </label>
  </template>
  
<script lang="ts" setup>
  import { ref } from 'vue'
  
  const value = ref('')
  const label = ref<HTMLDivElement | null>(null)
  const line = ref<HTMLDivElement | null>(null)
  const onFocus = () => {
      // 聚焦时,修改样式
      const labelEle = label.value
      const lineEle = line.value
      if (labelEle && lineEle)  {
          lineEle.style.width = '100%'
          labelEle.style.left = '0px'
          labelEle.style.top = '-30px'
         
      }
  }
  const onBlur = () => {
      // 如果有值,则不恢复
      if (value.value) return
      // 失焦时,恢复原装
      const labelEle = label.value
      const lineEle = line.value
      if (labelEle && lineEle)  {
          lineEle.style.width = '0px'
          labelEle.style.left = '5px'
          labelEle.style.top = '-4px'
          
      }
  }
</script>
  
<style lang="less" scoped>
  .input-container {
    display: block;
    position: relative;
    width: 100%;
    border-bottom: 1px solid black;
    .input {
      font-size: 16px;
      padding: 5px;
      width: 100%;
    }
    .label {
      font-size: 20px;
      position: absolute;
      left: 5px;
      top: 1px;
      user-select: none;
      font-weight: 500;
    }
    .line {
      height: 3px;
      width: 0;
      background-color: black;
    }
  }
</style>

相关推荐

3D边框效果绝了Jetpack Compose也太会玩了吧

在JetpackCompose中创建惊艳的3D边框效果大家好!今天我要分享一个超酷的技巧——如何在JetpackCompose中创建3D边框效果。这种效果可以应用于任何视图和任何形状...

“雨”你同行,他们在岗位上为您守护……

7月10日京津冀地区迎来降雨天气京铁人以“降雨预警”为令迎风而上逆水而行全力守护铁路运输安全雨帘下的“摆渡人”北京站、石家庄站及时铺设防滑垫,检查排水设施,确保旅客行走通道安全。北京北站加密站台巡视...

战士实用小福利!巧用宏命令让血条更直观

很多战士朋友经常被怒气和血条所困扰,如何及时的进行规避开启防御技能?如何更好的利用怒气打出伤害?成为了众多战士的首要问题。现在即使在没有插件的支持下我们也可以实现这样的功能,巧用宏命令就可以让怒气和血...

python操作word 添加导航栏,导航栏在左边显示

点赞标记,明天就能用上这几个技巧!要实现Python生成Word文档并显示左侧导航栏(即导航窗格),需通过标题样式标记文档结构+修改文档视图设置两步完成。以下是详细且经过验证的解决方案,基于pytho...

田渊栋等原班人马作:AI生成长篇故事,数千字长文也能连贯、有趣

机器之心报道编辑:小舟、陈萍以后,写故事这脑力活可以交给AI了。前段时间,模仿人类写作过程的语言模型Re^3发布,该模型不需要微调大模型,而是通过设计prompt来生成一致性强的故事。现在...

VBA常用代码_1、文本格式整理

本人财务岗位,非专业编程人员,请勿以专业看待哈,能用无BUG即可!均是我在工作中常用的补充功能,且具有通用性的功能。基于实用性而编写。不见理论,只需要你会复制粘贴就行。看完第一篇文章,结合之后更新的内...

行业首选的文档管理工具Aspose.Words新版本v16.3.0发布

Aspose.Words是一款先进的文档处理控件,在不使用MicrosoftWords的情况下,它可以使用户在各个应用程序中执行各种文档处理任务,其中包括文档的生成、修改、渲染、打印,文档格式转换和...

作为前端工程师必须懂得的33个CSS核心概念

你真的懂CSS吗?层叠样式表(CSS)是网页设计的支柱,能将单调的HTML转变为视觉惊艳的交互界面。要精通CSS,必须理解从基础选择器到动画、响应式设计等高级技巧在内的核心概念。无论你是初学者还是资深...

全力做好节假日期间服务保障工作

为保障五一期间ETC运营工作正常有序开展,甘肃省高速公路ETC管理服务中心全力以赴、恪尽职守,使各项工作有备无患。一是要求中心全体职工牢固树立安全发展观念,时刻紧绷“安全弦”,夯实安全生产基础,落实安...

Manila&#39;s hyping up of illegal &#39;arbitral award&#39; nothing but a damp squib

Manila'shypingupofillegal'arbitralaward'nothingbutadampsquib:ChinaDailyeditorial-Opi...

QLabel 文字两端对齐解决方案

在Qt开发中,实现QLabel文字两端对齐是一个常见需求。本文将介绍多种在Qt中实现QLabel文字两端对齐的方法及其原理。Qt本身具备文字两端对齐的支持,但需要同时使用Qt::AlignJ...

tkinter中的一些自定义控件,你知道几个呢?

用tkinter图形库编写过界面的朋友都知道,tkinter中拥有的图形控件很少,ttk中虽然新增了一些,但是这也不足以满足我们的使用,因为我们在编写图形界面的时候会用到各种各样的控件,有些是tkin...

一个人的婚礼:她送给自己的新婚礼物是遗体捐献书

style="text-indent:2em;">1月20日,在重庆武隆区医院的病房里,爱心人士为21岁的杨春燕在医院举办了一场没有新郎的婚礼,圆了春燕穿婚纱、走红毯的心愿,仪式后春燕签署了遗体...

毕业论文小技巧:word排版之章节自动化编号

设置大纲多级列表目的是方便增删章节时实现章节标号的自动编号,并且实现论文图表公式编号按照章节顺序自动编号。准备工作:假设前面已经定义好章节标题样式分别为标题一论文章标题、论文节标题、论文小节标题、论文...

伊朗呼吁土耳其立即终止对叙军事行动

style="text-indent:2em;">新华社德黑兰1月21日电(记者马骁穆东)伊朗外交部21日发表声明说,希望土耳其立即终止在叙利亚阿夫林发起的军事行动,避免叙北部危机进一步恶化。...