WPF 正確理解ContentPresenter

我們先由下圖來看類層次,可知ContentControl繼承Control,ContentPresenter繼承FrameworkElement(Control也繼承FrameworkElement);

同樣的,ItemsControl繼承Control,ItemsPresenter繼承FrameworkElement.

ScreenClip

在Control類並沒有Content屬性, 所以在這之上再寫了一個ContentControl, 使控件有Content屬性可以顯示內容, 而

ContentPresenter就是負責將Content屬性顯示出來.

 

接著來我們看一下實例,

 

實例1:不使用ContentPresenter

使用ContentPresenter

<ContentControl Content="YangMark"> <ContentControl.Template> <ControlTemplate TargetType="ContentControl"> <ContentPresenter></ContentPresenter> </ControlTemplate> </ContentControl.Template> </ContentControl>
輸出結果: YangMark
正確顯示Content!!
 
不使用ContentPresenter
<ContentControl Content="YangMark"> <ContentControl.Template> <ControlTemplate TargetType="ContentControl"> </ControlTemplate> </ContentControl.Template> </ContentControl>
 
輸出結果:
無法顯示出Content!!
 
結論1:ContentPresenter通常出現在ControlTemplate內,且若不使用ContentPresenter則
Content屬性就無法正常顯示。
 
 
實例2:ContentPresenter中的ContentSource屬性
為什麼只為了顯示出Content屬性要大費周張弄出ContentPresenter呢??
我們可以先比較以下兩種代碼不同之類,
<ContentControl Content="YangMark" ContentStringFormat="Hello!! {0}"> <ContentControl.Template> <ControlTemplate TargetType="ContentControl"> <ContentPresenter ContentSource="Content"></ContentPresenter> </ControlTemplate> </ContentControl.Template> </ContentControl>

輸出結果:Hello!! YangMark
 
<ContentControl Content="YangMark" ContentStringFormat="Hello!! {0}"> <ContentControl.Template> <ControlTemplate TargetType="ContentControl"> <ContentPresenter Content="{TemplateBinding Content}"></ContentPresenter> </ControlTemplate> </ContentControl.Template> </ContentControl>

 

輸出結果:YangMark
僅出現Content屬性的內容!!
 
結論2:<ContentPresenter/><ContentPresenter ContentSource="Content"/> 意義上是相同的。
它們同時綁定了Content, ContentStringFormat, ContentTemplate和ContentTemplateSelector等內容

屬性。

若僅用Content="{TemplateBinding Content}"代表只綁定Content屬性而已,且ContentSource會失效。
 
 

實例3:ContentSource的應用

以HeaderContentControl為例,使用ContentPresenter綁定內容屬性。
<HeaderedContentControl Header="Header" HeaderStringFormat="I'm {0}" Content="Content" ContentStringFormat="I'm {0}"> <HeaderedContentControl.Template> <ControlTemplate TargetType="HeaderedContentControl"> <DockPanel> <ContentPresenter ContentSource="Header" DockPanel.Dock="Top"></ContentPresenter> <!--等同於<ContentPresenter ContentSource="Content"/>--> <ContentPresenter></ContentPresenter> </DockPanel> </ControlTemplate> </HeaderedContentControl.Template> </HeaderedContentControl>


輸出結果:

I'm Header

I’m Content

 

結論3:ContentSource若指定對象為Content是可以省略的,若不為Content(如:Header)則不能省略。

 

 

總結:

Content, ContentStringFormat, ContentTemplate和ContentTemplateSelector等屬性, 我將它們稱為內容屬性.

1. ContentPresenter的作用就是用來顯示內容屬性

2.ContentSource若指定對象為Content,則等同於<ContentPresenter/>; 若指定對象不為Content,

   則必須使用ContentSource聲明指定的對象.

转载于:https://my.oschina.net/rotiwen/blog/293864

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值