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

el-input 重写带图标密码框(点击小眼睛显示、隐藏密码)

需求:

密码框在编辑输入状态下 和 disabled 禁用状态下 都可以展示明文和密文,官方组件在disabled 下不支持,需重写。

效果:

代码:
<template><el-inputid="password"placeholder="请输入密码"v-model="password"autocomplete="new-password":type="showPassword ? 'text' : 'password'":disabled="true"><template #suffix><i :class="showPassword ? 'icon icon-view' : 'icon icon-view-off'" @click="showPassword = !showPassword"></i></template></el-input>
</template><script>
export default {data() {return {password: '', // 绑定的密码值showPassword: false, // 控制密码是否显示为明文};},
};
</script>
<style lang="less" scoped>i.icon{display: inline-block;height: 20px;width: 20px;margin-left: 6px;position: relative;top: 3px;&:hover {cursor: pointer;}background: url('../../assets/image/view.png') center 2px no-repeat;background-size: contain;&.icon-view{background-image: url('../../assets/image/view.png');}&.icon-view-off{background-image: url('../../assets/image/viewoff.png');}}
</style>
扩展:
    @focus="showPassword = true"@blur="showPassword = false"
解释:
  1. v-model: 绑定输入框的值到password

  2. show-password: 这个属性在Element UI的el-input组件中已经存在,用于自动处理显示和隐藏密码的功能,但如果想自定义图标,可以忽略这个属性。

  3. @focus 和 @blur: 这两个事件处理器用来在输入框获得焦点和失去焦点时改变showPassword的状态。这有助于在用户点击小眼睛图标之前保持当前的显示状态。

  4. :type: 根据showPassword的值来切换输入框的类型,如果是文本则显示明文,如果是密码则显示为密文。

  5. template #suffix: 这是Element UI的插槽语法,用于在输入框后添加自定义内容(如小眼睛图标)。点击这个图标会切换showPassword的值。

  6. i标签的class: 根据showPassword的值切换图标,使用Element UI的内置图标类(如el-icon-viewel-icon-view-off)。确保项目中已经正确引入了这些图标。如果没有,可以自定义图标或使用其他库提供的图标。

http://www.xdnf.cn/news/18340.html

相关文章:

  • 当MySQL的int不够用了
  • 【教程】在 VMware Windows 虚拟机中使用 WinPE 进行离线密码重置或取证操作
  • 玛雅预言的技术性解构:历法算法、量子共振与文明预警机制
  • mongodb学习
  • Rust 入门 返回值和错误处理 (二十)
  • 编译器错误消息: CS0016: 未能写入输出文件“c:\Windows\Microsoft.NET... 拒绝访问
  • 跟踪不稳定目标:基于外观引导的运动建模实现无人机视频中的鲁棒多目标跟踪
  • GeoTools 读取影像元数据
  • OpenHarmony 之多模态输入子系统源码深度架构解析
  • Web3.0 时代的电商系统:区块链如何解决信任与溯源问题?
  • SWMM排水管网水力、水质建模及在海绵与水环境中的应用
  • C++常见面试题-2.C++类相关
  • EPM240T100I5N Altera FPGA MAX II CPLD
  • 深度学习-167-MCP技术之工具函数的设计及注册到MCP服务器的两种方式
  • TensorFlow 面试题及详细答案 120道(11-20)-- 操作与数据处理
  • 【Linux】文件系统
  • 前端面试核心技术30问
  • 《C++进阶之STL》【二叉搜索树】
  • 神经网络中的那些关键设计:从输入输出到参数更新
  • Python 函数进阶:深入理解参数、装饰器与函数式编程
  • Java 大视界 -- Java 大数据在智能物流无人配送车路径规划与协同调度中的应用
  • 暴雨中的“天眼”:天通哨兵PS02卫星图传系统筑牢防汛安全网
  • 前端面试题1
  • 边缘智能体:Go编译在医疗IoT设备端运行轻量AI模型(上)
  • Springboot使用Selenium+ChormeDriver在服务器(Linux)端将网页保存为图片或PDF
  • Rust学习笔记(七)|错误处理
  • 0819 使用IP多路复用实现TCP并发服务器
  • 反向代理实现服务器联网
  • Auto-CoT:大型语言模型的自动化思维链提示技术
  • 微服务-08.微服务拆分-拆分商品服务