5

我有一个按钮,它的内容(文本)通过样式针对支持属性动态设置,如下所示。

<Button>
   <Button.Style>
      <Style>
         <Setter Property="Button.Content" Value="Advanced Search" />
         <Style.Triggers>
            <DataTrigger Binding="{Binding Path=IsAdvancedSearch}" Value="True">
               <Setter Property="Button.Content" Value="Standard Search" />
            </DataTrigger>
         </Style.Triggers>
      </Style>
   </Button.Style>
</Button>

我需要更改此按钮以仅显示具有相同动态文本的超链接。像这样:

<Button>
   <Button.Template>
      <ControlTemplate>
         <TextBlock>
            <Hyperlink>
               Standard Search
            </Hyperlink>
         </TextBlock>
      </ControlTemplate>
   </Button.Template>
</Button>

有没有办法通过样式动态设置超链接的文本(内联或其他标签)?

我无法通过 XAML 访问它。我让它与超链接内的文本块上的普通绑定一起工作,但这确实在视图模型上创建了一个冗余属性。

4

4 回答 4

9

您可以在超链接中嵌入另一个 TextBlock 并绑定它:

<TextBlock>
    <Hyperlink>
        <TextBlock Text="{Binding LinkText}" />
    </Hyperlink>
</TextBlock>
于 2012-09-14T04:02:04.413 回答
5

解决方案是简单地将样式应用于内部文本块。

            <Button x:Name="SwitchSearchType">
                <Button.Template>
                    <ControlTemplate>
                        <TextBlock>
                            <Hyperlink>
                                <Hyperlink.Inlines>
                                    <TextBlock>
                                        <TextBlock.Style>
                                            <Style>
                                                <Setter Property="TextBlock.Text" Value="Advanced Search" />
                                                <Style.Triggers>
                                                    <DataTrigger Binding="{Binding Path=IsAdvancedSearch}" Value="True">
                                                        <Setter Property="TextBlock.Text" Value="Standard Search" />
                                                    </DataTrigger>
                                                </Style.Triggers>
                                            </Style>
                                        </TextBlock.Style>
                                    </TextBlock>
                                </Hyperlink.Inlines>
                            </Hyperlink>
                        </TextBlock>
                    </ControlTemplate>
                </Button.Template>
            </Button>
于 2012-09-17T07:39:46.533 回答
0
 <GridViewColumn Header="{x:Static lang:Lang.wName}"  CellTemplate="{StaticResource Template_DebitAccount}" />

And use into skin file 

<DataTemplate x:Key="Template_DebitAccount">
    <Border Padding="3" >
        <TextBlock Text="{Binding wDebitAccountName}" Style="{StaticResource TextStyle_Path}">
            <TextBlock.InputBindings>
                <MouseBinding MouseAction="LeftClick" Command="{Binding DataContext.Base_PopPageCommand , RelativeSource={RelativeSource AncestorType=ListView}}" >
                    <MouseBinding.CommandParameter>
                        <MultiBinding Converter="{StaticResource MultiValueBindingConverter}">
                            <Binding Source="AgentSummary" />
                            <Binding Path="Link_Text"/>
                        </MultiBinding>
                    </MouseBinding.CommandParameter>
                </MouseBinding>
            </TextBlock.InputBindings>
        </TextBlock>
    </Border>
</DataTemplate>
于 2017-02-13T15:56:26.577 回答
-2

鉴于:

<Hyperlink x:Name="uriEmailAddress" Click="Hyperlink_Click"></Hyperlink>

代码:

string e = Properties.Settings.Default.Email;
uriEmailAddress.NavigateUri = new Uri("mailto:" + e);
InlineCollection ic = uriEmailAddress.Inlines;
ic.Add(new Run(e));
于 2014-01-19T04:24:18.697 回答