- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如下图所示,我有两个由四个图像分隔的四个文本框。
我想要做的是,当我将焦点放在右侧的第一个文本框或左侧的第一个文本框上时,第一个左右箭头图像应该改变颜色。当失去焦点时,颜色应该变回灰色。如果用户转到左侧或右侧的第二个 TextBox,则第二个左右箭头图标应更改颜色,依此类推。我该怎么做?
我尝试使用 IsKeyboardFocusWithin TextBox 属性实现 MultiDataTrigger,但无法存档所需的结果。有什么建议吗?
这是我的 XAML 代码:(图标位于第二个 StackPanel 的 Path 属性内)
<StackPanel Grid.Column="0">
<telerik:RadWatermarkTextBox Name="WatermarkTextBoxP1"
WatermarkContent="Parameterausdruck P1"
Margin="0,5,0,0" TabIndex="1"/>
<telerik:RadWatermarkTextBox Name="WatermarkTextBoxP2"
WatermarkContent="Parameterausdruck P2"
Margin="0,5,0,0" TabIndex="3"/>
<telerik:RadWatermarkTextBox Name="WatermarkTextBoxP3"
WatermarkContent="Parameterausdruck P3"
Margin="0,5,0,0" TabIndex="5"/>
<telerik:RadWatermarkTextBox Name="WatermarkTextBoxP4"
WatermarkContent="Parameterausdruck P4"
Margin="0,5,0,0" TabIndex="7"/>
</StackPanel>
<StackPanel Grid.Column="1" Margin="0,5,0,0">
<Path Fill="Gray" Margin="5,5,5,0" Stretch="Fill" Width="14" Height="11"
Data="F1 M 54,52.0001L 29.25,52.0001L 37.25,60L 26.75,60L 14.75,48.0001L 26.75,36L 37.25,36L 29.25,44.0001L 54,44.0001L 54,52.0001 Z M 22,23.9999L 46.75,23.9999L 38.75,16L 49.25,16L 61.25,27.9999L 49.25,40L 38.75,40L 46.75,31.9999L 22,31.9999L 22,23.9999 Z " />
<Path Fill="Gray" Margin="5,16,5,0" Stretch="Fill" Width="14" Height="11"
Data="F1 M 54,52.0001L 29.25,52.0001L 37.25,60L 26.75,60L 14.75,48.0001L 26.75,36L 37.25,36L 29.25,44.0001L 54,44.0001L 54,52.0001 Z M 22,23.9999L 46.75,23.9999L 38.75,16L 49.25,16L 61.25,27.9999L 49.25,40L 38.75,40L 46.75,31.9999L 22,31.9999L 22,23.9999 Z " />
<Path Fill="Gray" Margin="5,16,5,0" Stretch="Fill" Width="14" Height="11"
Data="F1 M 54,52.0001L 29.25,52.0001L 37.25,60L 26.75,60L 14.75,48.0001L 26.75,36L 37.25,36L 29.25,44.0001L 54,44.0001L 54,52.0001 Z M 22,23.9999L 46.75,23.9999L 38.75,16L 49.25,16L 61.25,27.9999L 49.25,40L 38.75,40L 46.75,31.9999L 22,31.9999L 22,23.9999 Z " />
<Path Fill="Gray" Margin="5,16,5,0" Stretch="Fill" Width="14" Height="11"
Data="F1 M 54,52.0001L 29.25,52.0001L 37.25,60L 26.75,60L 14.75,48.0001L 26.75,36L 37.25,36L 29.25,44.0001L 54,44.0001L 54,52.0001 Z M 22,23.9999L 46.75,23.9999L 38.75,16L 49.25,16L 61.25,27.9999L 49.25,40L 38.75,40L 46.75,31.9999L 22,31.9999L 22,23.9999 Z " />
</StackPanel>
<StackPanel Grid.Column="2">
<telerik:RadWatermarkTextBox Name="WatermarkTextBoxDesignP1"
WatermarkContent="Design Wert P1"
Margin="0,5,0,0"
TabIndex="2"/>
<telerik:RadWatermarkTextBox Name="WatermarkTextBoxDesignP2"
WatermarkContent="Design Wert P2"
Margin="0,5,0,0"
TabIndex="4"/>
<telerik:RadWatermarkTextBox Name="WatermarkTextBoxDesignP3"
WatermarkContent="Design Wert P3"
Margin="0,5,0,0"
TabIndex="6"/>
<telerik:RadWatermarkTextBox Name="WatermarkTextBoxDesignP4"
WatermarkContent="Design Wert P4"
Margin="0,5,0,0"
TabIndex="8"/>
</StackPanel>
</Grid>
最佳答案
不是为每个文本框使用单独的样式,而是一种简单的小行为。它们具有可在整个应用程序中重复使用的优点,您可以稍后添加更多功能。这是一个例子:
此类被添加到 Path 中,并绑定(bind)到一个 FrameworkElement - FocusElement。每当该元素中的焦点发生变化时,它都会更改 Fill 属性。如果您希望在整个应用程序中使用不同的填充颜色,您可以添加填充颜色的属性,但我保持简单——在硬编码的橙色和灰色之间切换:
public class FocusHighlightBehavior : Behavior<Path>
{
public FrameworkElement FocusElement
{
get { return (FrameworkElement)GetValue(FocusElementProperty); }
set { SetValue(FocusElementProperty, value); }
}
// Using a DependencyProperty as the backing store for FocusElement.
public static readonly DependencyProperty FocusElementProperty =
DependencyProperty.Register("FocusElement", typeof(FrameworkElement), typeof(FocusHighlightBehavior), new PropertyMetadata(null, (o,e) =>
{
//this is the property changed event for the dependency property!
(o as FocusHighlightBehavior).UpdateFocusElement();
}));
private void UpdateFocusElement()
{
if (FocusElement != null)
{
FocusElement.GotFocus += FocusElement_GotFocus;
FocusElement.LostFocus += FocusElement_LostFocus;
}
}
private void FocusElement_LostFocus(object sender, RoutedEventArgs e)
{
AssociatedObject.Fill = Brushes.Gray;
}
private void FocusElement_GotFocus(object sender, RoutedEventArgs e)
{
AssociatedObject.Fill = Brushes.Orange;
}
}
只需将它添加到路径的 xaml 中即可使用它,如下所示:
<Path Fill="Gray" Margin="5,5,5,0" Stretch="Fill" Width="14" Height="11" Data="...">
<e:Interaction.Behaviors>
<local:FocusHighlightBehavior FocusElement="{Binding ElementName=WatermarkTextBoxP1}"/>
</e:Interaction.Behaviors>
</Path>
这是有效的:
请注意,您需要引用 System.Windows.Interactivity
,并将其包含在您的 xaml 中,如下所示:
<Window x:Class="TestApp.MainWindow"
....
xmlns:local="clr-namespace:TestApp"
xmlns:e="http://schemas.microsoft.com/expression/2010/interactivity"
关于c# - 基于 WPF 中的 TextBox Focus 更改图像颜色?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41446657/
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
我一直在尝试使用 Bootstrap 的表单样式处理 AngularJS 的电子邮件验证,并遇到了这个 CSS block 。 input:focus:required:invalid, textar
我在 bootstrap 中查看 dropdown.js 的历史,并在 git 上发现了以下更改历史文件,here : $this.focus() // focus() being changed
在不考虑性能的情况下,我总是认为 $(":focus") 返回的 jquery 对象等同于 $(document.activeElement)。 但是,如果您闯入浏览器调试器并评估 $(":focus
我使用 datatables from fluent kit和分页,当点击时(:active)突出显示: box-shadow: 0 0 0 0.2rem rgba(0,123,255,.25); 我
我的目标是在单击 span(带有 Show Me 文本)时显示带有 show 类的 p 标签。我曾尝试使用 :focus 伪选择器来执行此操作,但使用此方法使得 p 标记仅在单击其他位置之前显示,其中
result 我想让图片保持点击状态。 我为每个图标使用了两个图像。一个是什么时候没有被点击。另一个是何时单击。悬停工作正常。但焦点根本不起作用。 我没有看到任何错误或错误。请帮帮我! 这是 body
我在表格布局中嵌套了编辑文本,然后在 ScrollView 中嵌套了表格布局,触摸模式下的可聚焦/可聚焦在真实设备中不起作用,但令人惊讶的是它在模拟器中起作用。 请问能否提供一些替代解决方案? 最佳答
我使用 Backbone.js 的代码的 View 部分是这样的: var myView = Backbone.View.extend({ events: { 'focus .
我有一个行为类似于选项卡控件的用户控件。选项卡标题是 UserControl 实例,它们重写 Paint 事件以使它们看起来是自定义的。 为了利用选项卡页上各种控件上的验证事件,当用户单击选项卡标题时
我遇到了一个麻烦的网页,其结构很复杂。如果用鼠标单击一个DIV,则一切正常。但是,如果它是通过 javascript 获得焦点的(即 divElement.focus)。布局变得凌乱。这只发生在 IE
这是一个代码笔来演示我所看到的: https://codepen.io/anon/pen/zMvxPy HTML: JS: $('input').on('focus', () => { cons
问题: PrimeFaces“p:focus”标签不是聚焦。 - 即,当 xhtml 页面呈现给用户时,没有输入字段处于焦点。 问题: 为什么不呢?如何让“p:focus”在这个简单的应用程序中正常工
我有一个 只有当第一个子元素获得焦点而不是第二个子元素时,我才想在其中设置焦点的元素。我尝试使用 :not伪类,但没有成功。 值得注意的是,我仍然需要关注第二个元素,只是不想有两个焦点元素(父 + 子
我正在尝试用纯 CSS 创建一个可访问的下拉菜单,但我不太确定该怎么做。 如果 anchor 处于事件状态,我可以获得下一个 UL(子菜单),但是一旦进入子菜单,聚焦第一个链接,我不确定如何告诉 an
我在 jQuery UI 代码库中看到 .focus(1),但我无法弄清楚该参数的用途。 它与.focus()有何不同?我阅读了 jQuery 网站上的 .focus 文档,但仍然一无所知。 谢谢。
在 WPF 中,有两种方法可以将焦点设置到元素上。 您可以调用 input 元素的 .Focus() 方法,也可以使用 input 元素作为参数调用 Keyboard.Focus() 。 // fir
我有一个可以获得焦点的父组件。它使用这个焦点来提供键盘控制。该父组件可以生成一个子组件,该子组件同样可以获取焦点,以便它可以响应键盘事件。子组件监听的键盘事件之一是 这会导致子组件被卸载。 当子组件卸
我有一个可以获得焦点的父组件。它使用这个焦点来提供键盘控制。该父组件可以生成一个子组件,该子组件同样可以获取焦点,以便它可以响应键盘事件。子组件监听的键盘事件之一是 这会导致子组件被卸载。 当子组件卸
我试图突出焦点 秒。 我添加了 -1 的标签索引给他们每个人,并确认调用some_tr.focus()套document.activeElement那个some_tr .然而,由于某种原因some_t
我是一名优秀的程序员,十分优秀!