概述 TabControl是我们常用的翻页控件,但是wpf自带的TabControl功能和样式比较单一,假如我的tab页面比较多,标题在有限的空间放不下,需要用左右箭头翻页,同时需要加一个筛选跳转的功能,这时候我们就需要使用Dev的控件DXTabControl。功能演示 代码实现 前台XAML:spanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameUserControlspanspanclasscodesnippetattrx:ClassspanspanclasscodesnippetstringCaliburn。Micro。Hello。TabControlViewspanspanspanspanclasscodesnippetouterspanclasscodesnippetattrxmlnsspanspanclasscodesnippetstringhttp:schemas。microsoft。comwinfx2006xamlpresentationspanspanspanclasscodesnippetouterspanclasscodesnippetattrxmlns:xspanspanclasscodesnippetstringhttp:schemas。microsoft。comwinfx2006xamlspanspanspanclasscodesnippetouterspanclasscodesnippetattrxmlns:dspanspanclasscodesnippetstringhttp:schemas。microsoft。comexpressionblend2008spanspanspanclasscodesnippetouterspanclasscodesnippetattrxmlns:mcspanspanclasscodesnippetstringhttp:schemas。openxmlformats。orgmarkupcompatibility2006spanspanspanclasscodesnippetouterspanclasscodesnippetattrxmlns:dxspanspanclasscodesnippetstringhttp:schemas。devexpress。comwinfx2008xamlcorespanspanspanclasscodesnippetouterspanclasscodesnippetattrxmlns:dxlcspanspanclasscodesnippetstringhttp:schemas。devexpress。comwinfx2008xamllayoutcontrolspanspanspanclasscodesnippetouterspanclasscodesnippetattrxmlns:localspanspanclasscodesnippetstringclrnamespace:Caliburn。Micro。Hellospanspanspanclasscodesnippetouterspanclasscodesnippetattrxmlns:calspanspanclasscodesnippetstringhttp:www。caliburnproject。orgspanspanspanclasscodesnippetouterspanclasscodesnippetattrmc:IgnorablespanspanclasscodesnippetstringdspanspanclasscodesnippetattrHeightspanspanclasscodesnippetstring450spanspanclasscodesnippetattrWidthspanspanclasscodesnippetstring800spanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameGridspanspanclasscodesnippetattrHeightspanspanclasscodesnippetstring300spanspanclasscodesnippetattrWidthspanspanclasscodesnippetstring250spanspanclasscodesnippetattrHorizontalAlignmentspanspanclasscodesnippetstringLeftspanspanclasscodesnippetattrVerticalAlignmentspanspanclasscodesnippetstringTopspanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameGrid。RowDefinitionsspanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameRowDefinitionspanspanclasscodesnippetattrHeightspanspanclasscodesnippetstring35spanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameRowDefinitionspanspanclasscodesnippetattrHeightspanspanclasscodesnippetstringAutospanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameGrid。RowDefinitionsspanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameStackPanelspanspanclasscodesnippetattrOrientationspanspanclasscodesnippetstringHorizontalspanspanclasscodesnippetattrHorizontalAlignmentspanspanclasscodesnippetstringRightspanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameLabelspanspanclasscodesnippetattrContentspanspanclasscodesnippetstring跳转到页:spanspanclasscodesnippetattrVerticalAlignmentspanspanclasscodesnippetstringCenterspanspanclasscodesnippetattrMarginspanspanclasscodesnippetstring5spanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameTextBoxspanspanclasscodesnippetattrTextspanspanclasscodesnippetstring{BindingPageIndex}spanspanclasscodesnippetattrMinWidthspanspanclasscodesnippetstring50spanspanclasscodesnippetattrVerticalAlignmentspanspanclasscodesnippetstringCenterspanspanclasscodesnippetattrMarginspanspanclasscodesnippetstring5spanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameButtonspanspanclasscodesnippetattrContentspanspanclasscodesnippetstring跳转spanspanclasscodesnippetattrNamespanspanclasscodesnippetstringButtonClickspanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameStackPanelspanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnamedx:DXTabControlspanspanclasscodesnippetattrGrid。Rowspanspanclasscodesnippetstring1spanspanclasscodesnippetattrSelectedIndexspanspanclasscodesnippetstring{BindingSelectedIndex}spanspanspanspanclasscodesnippetouterspanclasscodesnippetattrItemsSourcespanspanclasscodesnippetstring{BindingParamItems}spanspanclasscodesnippetattrMarginspanspanclasscodesnippetstring5spanspanspanclasscodesnippetouterspanclasscodesnippetcomment!cal:Message。Attach〔EventSelectionChanged〕〔DXTabControlSelectionChanged()〕spanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnamedx:DXTabControl。ItemHeaderTemplatespanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameDataTemplatespanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameStackPanelspanspanclasscodesnippetattrOrientationspanspanclasscodesnippetstringHorizontalspanspanspanspanclasscodesnippetouterspanclasscodesnippetcomment!ImageSource{BindingImageLabel}spanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnamedxlc:LayoutItemspanspanclasscodesnippetattrLabelspanspanclasscodesnippetstring{BindingHeader}spanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameStackPanelspanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameDataTemplatespanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnamedx:DXTabControl。ItemHeaderTemplatespanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnamedx:DXTabControl。ItemTemplatespanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameDataTemplatespanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameContentControlspanspanclasscodesnippetattrcal:View。Modelspanspanclasscodesnippetstring{BindingSubView}spanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameDataTemplatespanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnamedx:DXTabControl。ItemTemplatespanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnamedx:DXTabControl。Viewspanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnamedx:TabControlScrollViewspanspanclasscodesnippetattrAllowHideTabItemsspanspanclasscodesnippetstringFalsespanspanclasscodesnippetattrAllowAnimationspanspanclasscodesnippetstringTruespanspanspanspanclasscodesnippetouterspanclasscodesnippetattrAllowKeyboardNavigationspanspanclasscodesnippetstringTruespanspanclasscodesnippetattrAllowScrollOnMouseWheelspanspanclasscodesnippetstringTruespanspanspanclasscodesnippetouterspanclasscodesnippetattrShowHeaderMenuspanspanclasscodesnippetstringTruespanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnamedx:DXTabControl。Viewspanspanspanspanclasscodesnippetouter spanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnamedx:DXTabControlspanspanspanspanclasscodesnippetouterspanclasscodesnippetcomment!dxg:GridControlspanspancodecodespanclasscodesnippetouterspanclasscodesnippetcommentdxg:GridControl。Viewspanspancodecodespanclasscodesnippetouterspanclasscodesnippetcommentdxg:TableViewAllowPagingTruespanspancodecodespanclasscodesnippetouterspanclasscodesnippetcommentdxg:GridControl。Viewspanspancodecodespanclasscodesnippetouterspanclasscodesnippetcommentdxg:GridControlspanspanspanclasscodesnippetouter spanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameGridspanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameUserControlspanspanspanspanclasscodesnippetouter span 这里的ShowHeaderMenuTrue可以放出筛选的按钮,点击下拉按钮,选择要跳转的页面就可以跳转过去; 如果想擦除页面,将AllowHideTabItems设置true即可 每个页面通过模板绑定了一个子页面 spanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnamedx:DXTabControl。ItemTemplatespanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameDataTemplatespanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameContentControlspanspanclasscodesnippetattrcal:View。Modelspanspanclasscodesnippetstring{BindingSubView}spanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnameDataTemplatespanspanspanspanclasscodesnippetouterspanclasscodesnippettagspanclasscodesnippetnamedx:DXTabControl。ItemTemplatespanspanspan 后台代码: spanclasscodesnippetouterspanclasscodesnippetkeywordusingspanPropertyChanged;spanspanclasscodesnippetouterspanclasscodesnippetkeywordusingspanSystem。Collections。ObjectModel;spanspanclasscodesnippetouter spanspanclasscodesnippetouterspanclasscodesnippetkeywordnamespacespanspanclasscodesnippettitleCaliburn。Micro。Hellospanspanspanclasscodesnippetouter{spanspanclasscodesnippetouter〔spanclasscodesnippetmetaAddINotifyPropertyChangedInterfacespan〕spanspanclasscodesnippetouterspanclasscodesnippetkeywordpublicspanspanclasscodesnippetkeywordclassspanspanclasscodesnippettitleTabControlViewModelspan:spanclasscodesnippettitleScreenspan,spanclasscodesnippettitleIViewModelspanspanspanclasscodesnippetouter{spanspanclasscodesnippetouterspanclasscodesnippetkeywordpublicspanObservableCollectionParamDTOParamItems{spanclasscodesnippetkeywordgetspan;spanclasscodesnippetkeywordsetspan;}spanclasscodesnippetkeywordnewspanObservableCollectionParamDTO();spanspanclasscodesnippetouterspanclasscodesnippetkeywordpublicspanspanclasscodesnippetkeywordintspanSelectedIndex{spanclasscodesnippetkeywordgetspan;spanclasscodesnippetkeywordsetspan;}spanspanclasscodesnippetouterspanclasscodesnippetkeywordpublicspanspanclasscodesnippetkeywordintspanPageIndex{spanclasscodesnippetkeywordgetspan;spanclasscodesnippetkeywordsetspan;}spanspanclasscodesnippetouterspanclasscodesnippetfunctionspanclasscodesnippetkeywordpublicspanspanclasscodesnippettitleTabControlViewModelspan(spanclasscodesnippetparamsspan)spanspanspanclasscodesnippetouter{spanspanclasscodesnippetouterDisplayNamespanclasscodesnippetstringTabControlTestspan;spanspanclasscodesnippetouterPageIndexspanclasscodesnippetnumber3span;spanspanclasscodesnippetouter spanspanclasscodesnippetouterParamItems。Add(spanclasscodesnippetkeywordnewspanParamDTO(){Headerspanclasscodesnippetstring1span,SubViewspanclasscodesnippetkeywordnewspanSubTabPageViewModel()});spanspanclasscodesnippetouterParamItems。Add(spanclasscodesnippetkeywordnewspanParamDTO(){Headerspanclasscodesnippetstring2span,SubViewspanclasscodesnippetkeywordnewspanSubTabPageViewModel()});spanspanclasscodesnippetouterParamItems。Add(spanclasscodesnippetkeywordnewspanParamDTO(){Headerspanclasscodesnippetstring3span,SubViewspanclasscodesnippetkeywordnewspanSubTabPageViewModel()});spanspanclasscodesnippetouterParamItems。Add(spanclasscodesnippetkeywordnewspanParamDTO(){Headerspanclasscodesnippetstring4span,SubViewspanclasscodesnippetkeywordnewspanSubTabPageViewModel()});spanspanclasscodesnippetouterParamItems。Add(spanclasscodesnippetkeywordnewspanParamDTO(){Headerspanclasscodesnippetstring5span,SubViewspanclasscodesnippetkeywordnewspanSubTabPageViewModel()});spanspanclasscodesnippetouterParamItems。Add(spanclasscodesnippetkeywordnewspanParamDTO(){Headerspanclasscodesnippetstring6span,SubViewspanclasscodesnippetkeywordnewspanSubTabPageViewModel()});spanspanclasscodesnippetouterParamItems。Add(spanclasscodesnippetkeywordnewspanParamDTO(){Headerspanclasscodesnippetstring7span,SubViewspanclasscodesnippetkeywordnewspanSubTabPageViewModel()});spanspanclasscodesnippetouterParamItems。Add(spanclasscodesnippetkeywordnewspanParamDTO(){Headerspanclasscodesnippetstring8span,SubViewspanclasscodesnippetkeywordnewspanSubTabPageViewModel()});spanspanclasscodesnippetouterParamItems。Add(spanclasscodesnippetkeywordnewspanParamDTO(){Headerspanclasscodesnippetstring9span,SubViewspanclasscodesnippetkeywordnewspanSubTabPageViewModel()});spanspanclasscodesnippetouterParamItems。Add(spanclasscodesnippetkeywordnewspanParamDTO(){Headerspanclasscodesnippetstring10span,SubViewspanclasscodesnippetkeywordnewspanSubTabPageViewModel()});spanspanclasscodesnippetouterParamItems。Add(spanclasscodesnippetkeywordnewspanParamDTO(){Headerspanclasscodesnippetstring11span,SubViewspanclasscodesnippetkeywordnewspanSubTabPageViewModel()});spanspanclasscodesnippetouterParamItems。Add(spanclasscodesnippetkeywordnewspanParamDTO(){Headerspanclasscodesnippetstring12span,SubViewspanclasscodesnippetkeywordnewspanSubTabPageViewModel()});spanspanclasscodesnippetouter}spanspanclasscodesnippetouter spanspanclasscodesnippetouterspanclasscodesnippetfunctionspanclasscodesnippetkeywordpublicspanspanclasscodesnippetkeywordvoidspanspanclasscodesnippettitleButtonClickspan(spanclasscodesnippetparamsspan)spanspanspanclasscodesnippetouter{spanspanclasscodesnippetouterSelectedIndexPageIndexspanclasscodesnippetnumber1span;spanspanclasscodesnippetouter}spanspanclasscodesnippetouter}spanspanclasscodesnippetouterspanclasscodesnippetkeywordpublicspanspanclasscodesnippetkeywordclassspanspanclasscodesnippettitleParamDTOspanspanspanclasscodesnippetouter{spanspanclasscodesnippetouterspanclasscodesnippetcommentspanclasscodesnippetdoctagspanspanclasscodesnippetdoctagsummaryspanspanspanspanclasscodesnippetouterspanclasscodesnippetcommentspanclasscodesnippetdoctagspan标题spanspanspanclasscodesnippetouterspanclasscodesnippetcommentspanclasscodesnippetdoctagspanspanclasscodesnippetdoctagsummaryspanspanspanspanclasscodesnippetouterspanclasscodesnippetkeywordpublicspanspanclasscodesnippetkeywordstringspanHeader{spanclasscodesnippetkeywordgetspan;spanclasscodesnippetkeywordsetspan;}spanspanclasscodesnippetouter spanspanclasscodesnippetouterspanclasscodesnippetcommentspanclasscodesnippetdoctagspanspanclasscodesnippetdoctagsummaryspanspanspanspanclasscodesnippetouterspanclasscodesnippetcommentspanclasscodesnippetdoctagspanSubViewspanspanspanclasscodesnippetouterspanclasscodesnippetcommentspanclasscodesnippetdoctagspanspanclasscodesnippetdoctagsummaryspanspanspanspanclasscodesnippetouterspanclasscodesnippetkeywordpublicspanSubTabPageViewModelSubView{spanclasscodesnippetkeywordgetspan;spanclasscodesnippetkeywordsetspan;}spanspanclasscodesnippetouter}spanspanclasscodesnippetouter spanspanclasscodesnippetouter}span 这里ParamDTO是数据模型,SubView就是我们的子页面 源码下载 百度网盘链接:https:pan。baidu。coms1JuD8PHUacDNIt7iCvxRBw 提取码:6666 dev控件官网学习网址:https:docs。devexpress。comWPFDevExpress。Xpf。Core。DXTabControl