眨眼睛查看密碼工具類

“眨眼睛查看密碼”工具類實現思路:


一、核心功能

實現點擊眼睛圖標切換密碼明文/星號顯示,提升表單輸入體驗。包含以下關鍵功能:
? 初始狀態:密碼框顯示為星號,閉眼圖標可見。
? 點擊閉眼圖標:切換為明文顯示,睜眼圖標可見。
? 點擊睜眼圖標:恢復星號顯示,閉眼圖標可見。


二、組件準備

  1. 兩個輸入框
    ? PasswordField:默認顯示星號的密碼輸入框。
    ? TextField:顯示明文的文本框(初始隱藏)。
  2. 兩個圖標控件
    ? ImageView openEye:睜眼圖標(初始隱藏)。
    ? ImageView closeEye:閉眼圖標(初始顯示)。

三、實現步驟

1. 初始化狀態

? 隱藏明文框visiblePasswordField.setVisible(false)
? 顯示密碼框passwordField.setVisible(true)
? 圖標狀態:顯示閉眼圖標,隱藏睜眼圖標。

2. 事件綁定

? 監聽兩個圖標的點擊事件:無論點擊哪個圖標,觸發切換邏輯。

openEye.setOnMouseClicked(e -> handleOpenEye());
closeEye.setOnMouseClicked(e -> handleOpenEye());
3. 切換邏輯實現

? 判斷當前顯示狀態:根據明文框是否可見決定下一步動作。

boolean isPasswordVisible = visiblePasswordField.isVisible();

? 切換到明文顯示
? 將密碼框內容復制到明文框:visiblePasswordField.setText(passwordField.getText())
? 顯示明文框,隱藏密碼框。
? 切換圖標狀態:顯示睜眼,隱藏閉眼。
? 切換到星號顯示
? 將明文內容復制回密碼框:passwordField.setText(visiblePasswordField.getText())
? 顯示密碼框,隱藏明文框。
? 切換圖標狀態:顯示閉眼,隱藏睜眼。


四、關鍵問題處理

? 文本同步:切換時同步內容,避免切換后數據不一致。
? 焦點管理:切換時保持輸入焦點,避免用戶需要重新點擊輸入框。
? 空值處理:確保null或空字符串時不會拋出異常。


五、優化建議

? 雙向綁定(可選):
使用JavaFX屬性綁定,實現兩個輸入框內容實時同步,避免手動復制。

visiblePasswordField.textProperty().bindBidirectional(passwordField.textProperty());

? 圖標樣式
添加CSS懸浮效果(如手指光標),提升用戶體驗。
? 輸入監聽
限制明文框的輸入類型(如僅允許特定字符)。


六、使用示例

// 在FXML控制器中初始化工具類
ExchangeEyeTUtil eyeUtil = new ExchangeEyeTUtil(visiblePwdField, passwordField, openEyeIcon, closeEyeIcon
);

總結:該工具類通過狀態切換和事件監聽,實現密碼可見性控制,核心在于正確處理組件顯示/隱藏狀態及內容同步。開發者可結合具體需求進行擴展優化。

package com.example.demo6.util;import javafx.fxml.FXML;
import javafx.scene.control.PasswordField;
import javafx.scene.control.TextField;
import javafx.scene.image.ImageView;public class ExchangeEyeTUtil {private final TextField visiblePasswordField;private final PasswordField passwordField;private final ImageView openEye;private final ImageView closeEye;public ExchangeEyeTUtil(TextField visiblePasswordField, PasswordField passwordField, ImageView openEye, ImageView closeEye) {this.visiblePasswordField = visiblePasswordField;this.passwordField = passwordField;this.openEye = openEye;this.closeEye = closeEye;// 初始狀態設置initialize();}@FXMLprivate void initialize() {// 初始化時隱藏明文輸入框和睜眼圖標visiblePasswordField.setVisible(false);openEye.setVisible(false);closeEye.setVisible(true);}@FXMLpublic void handleOpenEye() {// 判斷當前是否顯示明文boolean isPasswordVisible = visiblePasswordField.isVisible();if (isPasswordVisible) {// 切換到密碼隱藏狀態passwordField.setText(visiblePasswordField.getText());passwordField.setVisible(true);visiblePasswordField.setVisible(false);openEye.setVisible(false);closeEye.setVisible(true);} else {// 切換到明文顯示狀態visiblePasswordField.setText(passwordField.getText());visiblePasswordField.setVisible(true);passwordField.setVisible(false);openEye.setVisible(true);closeEye.setVisible(false);}}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/76027.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/76027.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/76027.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【GPT入門】第33課 從應用場景出發,區分 TavilyAnswer 和 TavilySearchResults,代碼實戰

【GPT入門】第33課 從應用場景出發,區分 TavilyAnswer 和 TavilySearchResults,代碼實戰 1. 區別應用場景 2. 代碼使用3.代碼執行效果 在langchain_community.tools.tavily_search中,TavilyAnswer和TavilySearchResults有以下區別和應用場景&…

【Java設計模式】第10章 外觀模式講解

10. 外觀模式 10.1 外觀模式講解 定義:為子系統提供統一接口,簡化調用。類型:結構型模式適用場景: 子系統復雜需簡化調用分層系統需統一入口優點: 降低耦合符合迪米特法則(最少知道原則)缺點: 擴展子系統需修改外觀類,違反開閉原則10.2 外觀模式 Coding // 子系統:…

Dubbo的簡單介紹

Dubbo的簡單介紹 Dubbo 是一個高性能的 Java RPC 框架,最初由阿里巴巴開發,用于構建分布式服務。它主要用于提供服務間的通信,支持高效的遠程調用和服務治理,常用于大規模分布式系統中。Dubbo 提供了以下幾個核心功能&#xff1a…

每日一題(小白)數組娛樂篇17

對一個數組進行接收進行操作后輸出。輸入三個操作數abc,將數組下標a到b的數字加上c;輸入四個操作數abcd,將下標c到d的數字復制到a到b,可以借用一個中間量數組實現;兩個操作數ab,將數組下標a到b的數字加和輸…

總結一下常見的EasyExcel面試題

說一下你了解的POI和EasyExcel POI(Poor Obfuscation Implementation):它是 Apache 軟件基金會的一個開源項目,為 Java 程序提供了讀寫 Microsoft Office 格式文件的功能,支持如 Excel、Word、PowerPoint 等多種文件格…

01-Redis-基礎

1 redis誕生歷程 redis的作者筆名叫做antirez,2008年的時候他做了一個記錄網站訪問情況的系統,比如每天有多少個用戶,多少個頁面被瀏覽,訪客的IP、操作系統、瀏覽器、使用的搜索關鍵詞等等(跟百度統計、CNZZ功能一樣)。最開始存儲…

在 Ubuntu 上離線安裝 Prometheus 和 Grafana

在 Ubuntu 上離線安裝 Prometheus 和 Grafana 的步驟如下: 一.安裝驗證 二.安裝步驟 1.準備離線安裝包 在一臺可以訪問互聯網的機器上下載 Prometheus 和 Grafana 的二進制文件。 Prometheus 下載地址:Prometheus 官方下載頁面Grafana 下載地址:Grafana 官方下載頁面下載所…

mapbox基礎,加載ESRI OpenStreetMap開放街景標準風格矢量圖

????? 主頁: gis分享者 ????? 感謝各位大佬 點贊?? 收藏? 留言?? 加關注?! ????? 收錄于專欄:mapbox 從入門到精通 文章目錄 一、??前言1.1 ??mapboxgl.Map 地圖對象1.1 ??mapboxgl.Map style屬性二、??加載ESRI OpenStreetMap開放街景標準風…

Java 集合有序性與重復性總結及記憶技巧

Java 集合有序性與重復性總結及記憶技巧 一、集合分類速查表 集合類型是否有序是否允許重復記憶口訣ArrayList? 有序(插入順序)? 可重復"數組列表,順序記牢"LinkedList? 有序(插入順序)? 可重復"…

記錄學習的第二十三天

老樣子,每日一題開胃。 我一開始還想著暴力解一下試試呢,結果不太行😂 接著兩道動態規劃。 這道題我本來是想用最長遞增子序列來做的,不過實在是太麻煩了,實在做不下去了。 然后看了題解,發現可以倒著數。 …

MTK-Android12-13 屏幕永不休眠功能實現

MTK-Android12-13 屏幕永不休眠功能實現 文章目錄 需求場景參考資料修改文件簡要分析實現方案默認休眠時間設置 def_screen_off_timeout息屏時間添加永不休眠 screen_timeout_entries更新休眠時間 updateUserActivitySummaryLocked 總結 需求 屏幕永不休眠功能 備注&#xff…

Lua 中,`math.random` 的詳細用法

在 Lua 中&#xff0c;math.random 是用于生成偽隨機數的核心函數。以下是其詳細用法、注意事項及常見問題的解決方案&#xff1a; Lua 中&#xff0c;math.random 的詳細用法—目錄 一、基礎用法1. 生成隨機浮點數&#xff08;0 ≤ x < 1&#xff09;2. 生成指定范圍的隨機…

HOW - React Error Catch 機制

目錄 1. 錯誤邊界&#xff08;Error Boundaries&#xff09;使用場景寫法&#xff08;類組件方式&#xff09;&#xff1a;componentDidCatch 2. 事件處理器中的錯誤3. 異步函數中的錯誤&#xff08;如 fetch、Promise&#xff09;4. 全局未捕獲錯誤&#xff08;適用于整個 Rea…

1.ElasticSearch-入門基礎操作

一、介紹 The Elastic Stack 包含ElasticSearch、Kibana、Beats、LogStash 這就是所說的ELK 能夠安全可靠地獲取任何來源、任何格式的數據&#xff0c;然后實時地對數據進行搜索、分析和可視化。Elaticsearch,簡稱為ES&#xff0c;ES是一個開源的高擴展的分布式全文搜索引擎,是…

通過扣子平臺將數據寫入飛書多維表格

目錄 1.1 創建飛書開放平臺應用 1.2 創建飛書多維表格 1.3 創建扣子平臺插件 1.1 創建飛書開放平臺應用 1.1.1 打開地址&#xff1a;飛書開放平臺&#xff0c;點擊創建應用 注&#xff1a;商店應用需要申請ISV資質&#xff0c;填寫企業主體信息&#xff0c;個人的話&#x…

MYSQL數據庫語法補充

一&#xff0c;DQL基礎查詢 DQL&#xff08;Data Query Language&#xff09;數據查詢語言&#xff0c;可以單表查詢&#xff0c;也可以多表查詢 語法&#xff1a; select 查詢結果 from 表名 where 條件&#xff1b; 特點&#xff1a; 查詢結果可以是&#xff1a;表中的字段…

Redis到底能不能做主數據庫?

張三拍案而起&#xff1a;“Redis 是緩存數據庫&#xff0c;怎么能當主數據庫用&#xff1f;簡直是天方夜譚&#xff01;” 李四冷笑回應&#xff1a;“你沒用過&#xff0c;憑什么說不行&#xff1f;我已經用 Redis 做主數據庫好幾年了&#xff0c;系統穩定得像鐵板一塊&…

flutter 項目結構目錄以及pubspec.ymal等文件描述

在Flutter項目中&#xff0c;目錄結構和pubspec.yaml文件是非常重要的組成部分&#xff0c;它們定義了項目的結構、依賴管理以及如何構建和運行項目。下面我將詳細解釋這些關鍵元素&#xff1a; 1. Flutter項目目錄結構 Flutter項目的標準目錄結構通常如下所示&#xff1a; …

CentOS 環境下 MySQL 數據庫全部備份的操作指南

最近阿里云個人服務到期&#xff0c;因為是很久之前買的測試機器&#xff0c;配置較低&#xff0c;上面運行的有技術博客 和以往的測試項目&#xff0c;所以準備放棄掉。 需要備份下上面的表結構和數據、以及代碼倉庫。 下面是一個完整的 CentOS 環境下 MySQL 數據庫全部備份…

ecplise 工具 沒有Java EE Tools 選項

Java EE Tools 是將項目轉換為web項目的重要的快捷鍵&#xff0c;如果進行web開發 那是不可或缺的 該工具是一個插件&#xff0c;可以作為插件安裝到ecplise上 安裝步驟如下&#xff1a; 找到help-->install new software 在彈出的頁面中 work with中輸入&#xff1a;Jun…