方法: ハイパーリンクに下線を引くかどうかを指定する

Hyperlink オブジェクトは、フロー コンテンツにハイパーリンクをホストする、インライン レベルのフロー コンテンツ要素です。 既定では、Hyperlink では下線を表示するために TextDecoration オブジェクトが使用されます。 TextDecoration オブジェクトをインスタンス化するときは大きな負荷がかかる場合があり、Hyperlink オブジェクトの数が多い場合は特にそうです。 Hyperlink 要素を多数使用する場合は、MouseEnter イベントなどのイベントがトリガーされるときにのみ下線を表示することを検討してください。

次の例では、"My MSN" リンクの下線は、MouseEnter イベントがトリガーされたときにだけ表示される動的なものです。

Hyperlinks displaying TextDecorations

次のマークアップ サンプルでは、下線ありとなしで定義された Hyperlink を示しています。

<!-- Hyperlink with default underline. -->
<Hyperlink NavigateUri="http://www.msn.com">
  MSN Home
</Hyperlink>

<Run Text=" | " />

<!-- Hyperlink with no underline. -->
<Hyperlink Name="myHyperlink" TextDecorations="None"
           MouseEnter="OnMouseEnter"
           MouseLeave="OnMouseLeave"
           NavigateUri="http://www.msn.com">
  My MSN
</Hyperlink>

次のコード サンプルでは、MouseEnter イベントで Hyperlink に下線を作成し、MouseLeave イベントで削除する方法を示しています。

// Display the underline on only the MouseEnter event.
private void OnMouseEnter(object sender, EventArgs e)
{
    myHyperlink.TextDecorations = TextDecorations.Underline;
}

// Remove the underline on the MouseLeave event.
private void OnMouseLeave(object sender, EventArgs e)
{
    myHyperlink.TextDecorations = null;
}
' Display the underline on only the MouseEnter event.
Private Overloads Sub OnMouseEnter(ByVal sender As Object, ByVal e As EventArgs)
    myHyperlink.TextDecorations = TextDecorations.Underline
End Sub

' Remove the underline on the MouseLeave event.
Private Overloads Sub OnMouseLeave(ByVal sender As Object, ByVal e As EventArgs)
    myHyperlink.TextDecorations = Nothing
End Sub

関連項目