32.失焦提示 C#例子 WPF例子

一个提示输入,但是会在输入和聚焦时消失,其他时候显示

原理就是一旦聚焦就不显示提示

失焦时如果有内容不操作、没有内容就显示提示

C#代码:

cs 复制代码
using System.Windows;
using System.Windows.Controls;
using System.Windows.Input;

namespace practice
{
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
        }

        private void got_Focus(object sender, RoutedEventArgs e)
        {
            TextBlock1.Visibility = Visibility.Collapsed;
        }

        private void lost_Focus(object sender, RoutedEventArgs e)
        {
            if (string.IsNullOrWhiteSpace(TextBox1.Text))
            {
                TextBlock1.Visibility = Visibility.Visible;
            }
        }
    }
}

XAML代码:

XML 复制代码
<Window x:Class="practice.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:practice"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
    <Grid>
        <TextBox Name="TextBox1" Width="300" VerticalAlignment="Center" HorizontalAlignment="Center" GotFocus="got_Focus" LostFocus="lost_Focus"/>
        <TextBlock Name="TextBlock1" Text="请在这里输入" VerticalAlignment="Center" HorizontalAlignment="Center" Foreground="Gray" IsHitTestVisible="False"/>
        <TextBox HorizontalAlignment="Left" Margin="250,170,0,0" TextWrapping="Wrap" Text="TextBox" VerticalAlignment="Top" Width="120"/>

    </Grid>
</Window>

Label用于说明,比如放在按钮前

Textblock用于显示

常见的属性

VerticalAlignment="Center":垂直对齐方式设置为居中。

HorizontalAlignment="Center":水平对齐方式设置为居中。

foreground="Gray": 这个属性设置了元素的前景色

IsHitTestVisible="False": 这个属性指定元素是否参与命中测试。命中测试是UI框架用来确定用户输入(如鼠标点击或触摸)是否指向特定元素的过程。当IsHitTestVisible设置为False时,元素将不会响应鼠标事件、触摸事件等用户交互。这通常用于使元素在视觉上可见但不可交互,例如,用于显示信息但不希望用户能够点击或与之交互的文本或图形。

PlaceholderTextBlock.Visibility = Visibility.Collapsed;

Visible 表示控件是可见的,它会占据布局空间。

Collapsed 表示控件是不可见的,并且它不会占据任何布局空间。这与 Hidden 不同(尽管在某些UI框架中可能存在 Hidden 状态),Hidden 通常意味着控件不可见但仍然占据其布局空间。

相关推荐
tiger从容淡定是人生2 分钟前
AI替代软件战略(一):从 CCleaner 到 MCP 架构重构 —— TigerCleaner 的工程实践
人工智能·重构·架构·c#·mcp
qq_454245031 小时前
从 UI 操作到环境交互:一种通用元命令自动化协议的设计与意义
人工智能·ui·自动化·交互
格林威1 小时前
工业视觉检测:提供可视化UI调试工具的实现方式是什么?
开发语言·人工智能·数码相机·ui·计算机视觉·视觉检测·工业相机
ZC跨境爬虫3 小时前
跟着 MDN 学 HTML day_8:(高级文本语义标签+适配核心功底)
前端·css·笔记·ui·html
橙子1991101614 小时前
UI 绘制相关
ui
Math_teacher_fan15 小时前
Flutter 跨平台开发实战:鸿蒙与音乐律动艺术(六)、Lissajous 利萨茹曲线:频率耦合的轨迹艺术
flutter·ui·数学建模·华为·harmonyos·鸿蒙系统
KmSH8umpK19 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第三篇
redis·分布式·wpf
宝桥南山20 小时前
GitHub Models - 尝试一下使用GitHub Models
microsoft·ai·微软·c#·github·.netcore
jiejiejiejie_20 小时前
Flutter for OpenHarmony 萌系 UI 实战合集:骨架屏 + 引导页一站式指南
flutter·ui·华为
Ulyanov20 小时前
《现代 Python 桌面应用架构实战:PySide6 + QML 从入门到工程化》 开发环境搭建与工具链极简主义 —— 拒绝臃肿,构建工业级基座
开发语言·python·qt·ui·架构·系统仿真