如何间隔 StackPanel 的子元素?
给定一个 StackPanel:
<StackPanel>
<TextBox Height="30">Apple</TextBox>
<TextBox Height="80">Banana</TextBox>
<TextBox Height="120">Cherry</TextBox>
</StackPanel>
即使子元素本身大小不同,间隔子元素以使它们之间的间隙大小相同的最佳方法是什么? 是否可以在不为每个单独的子项设置属性的情况下完成此操作?
Given a StackPanel:
<StackPanel>
<TextBox Height="30">Apple</TextBox>
<TextBox Height="80">Banana</TextBox>
<TextBox Height="120">Cherry</TextBox>
</StackPanel>
What's the best way to space out the child elements so that there are equally-sized gaps between them, even though the child elements themselves are of different sizes? Can it be done without setting properties on each of the individual children?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(11)
使用 Margin 或 Padding,应用于容器内的范围:
编辑:如果您想重复使用两个容器之间的边距,您可以将边距值转换为外部范围 fe 中的资源,
然后参考此内部范围内的值
Use Margin or Padding, applied to the scope within the container:
EDIT: In case you would want to re-use the margin between two containers, you can convert the margin value to a resource in an outer scope, f.e.
and then refer to this value in the inner scope
另一个不错的方法可以在这里看到:
http://blogs.microsoft.co.il/blogs/eladkatz/archive/2011/05/29/what-is-the-easiest-way-to-set-spacing -after-items-in-stackpanel.aspx
链接已损坏-> 这是此链接的网络存档。
它展示了如何创建附加行为,以便像这样的语法可以工作:
这是最简单的& 为面板的多个子项设置边距的最快方法,即使它们不是同一类型。 (即按钮、文本框、组合框等)
Another nice approach can be seen here:
http://blogs.microsoft.co.il/blogs/eladkatz/archive/2011/05/29/what-is-the-easiest-way-to-set-spacing-between-items-in-stackpanel.aspx
Link is broken -> this is webarchive of this link.
It shows how to create an attached behavior, so that syntax like this would work:
This is the easiest & fastest way to set Margin to several children of a panel, even if they are not of the same type. (I.e. Buttons, TextBoxes, ComboBoxes, etc.)
我改进了 Elad Katz 的回答。
要点中的源代码。
例子:
I improved on Elad Katz' answer.
Source code in gist.
Example:
您真正想做的事情是包装所有子元素。 在这种情况下,您应该使用项目控件,而不是诉诸可怕的附加属性,对于您想要设置样式的每个属性,您最终都会拥有一百万个附加属性。
The thing you really want to do is wrap all child elements. In this case you should use an items control and not resort to horrible attached properties which you will end up having a million of for every property you wish to style.
谢尔盖的回答+1。 如果您想将其应用于所有 StackPanel,您可以执行以下操作:
但要注意:如果您在 App.xaml(或合并到 Application.Resources 中的另一个字典)中定义了这样的样式)它可以覆盖控件的默认样式。 对于像 stackpanel 这样的大多数外观控件来说,这不是问题,但对于文本框等,您可能会偶然发现 这个问题,幸运的是有一些解决方法。
+1 for Sergey's answer. And if you want to apply that to all your StackPanels you can do this:
But beware: if you define a style like this in your App.xaml (or another dictionary that is merged into the Application.Resources) it can override the default style of the control. For mostly lookless controls like the stackpanel it isn't a problem, but for textboxes etc you may stumble upon this problem, which luckily has some workarounds.
根据 Sergey 的建议,您可以定义和重用整个 Style(具有各种属性设置器,包括 Margin),而不仅仅是一个 Thickness 对象:
...
请注意,这里的技巧是使用 Style Inheritance 来实现隐式样式,继承来自某些外部(可能从外部 XAML 文件合并)资源字典中的样式。
旁注:
起初,我天真地尝试使用隐式样式将控件的 Style 属性设置为外部 Style 资源(例如使用“MyStyle”键定义):
这导致 Visual Studio 2010立即关闭并出现灾难性故障错误(HRESULT:0x8000FFFF (E_UNEXPECTED)),如 https://connect.microsoft.com/VisualStudio/feedback/details/753211/xaml-editor -当-a-style-tries-to-set-style-property时窗口失败并出现灾难性失败#
Following up on Sergey's suggestion, you can define and reuse a whole Style (with various property setters, including Margin) instead of just a Thickness object:
...
Note that the trick here is the use of Style Inheritance for the implicit style, inheriting from the style in some outer (probably merged from external XAML file) resource dictionary.
Sidenote:
At first, I naively tried to use the implicit style to set the Style property of the control to that outer Style resource (say defined with the key "MyStyle"):
which caused Visual Studio 2010 to shut down immediately with CATASTROPHIC FAILURE error (HRESULT: 0x8000FFFF (E_UNEXPECTED)), as described at https://connect.microsoft.com/VisualStudio/feedback/details/753211/xaml-editor-window-fails-with-catastrophic-failure-when-a-style-tries-to-set-style-property#
UniformGrid 可能在 Silverlight 中不可用,但有人已经从 WPF 移植了它。 http://www.jeff.wilcox.name/2009/01/uniform -网格/
The UniformGrid might not be available in Silverlight, but someone has ported it from WPF. http://www.jeff.wilcox.name/2009/01/uniform-grid/
我的方法继承了StackPanel。
用法:
所需要的只是以下简短的课程:
My approach inherits StackPanel.
Usage:
All that's needed is the following short class:
Grid.ColumnSpacing, Grid.RowSpacing, StackPanel.Spacing 是现在在 UWP 预览版中,一切都将允许更好地完成此处的要求。
这些属性目前仅适用于 Windows 10 Fall Creators Update Insider SDK,但应该会进入最后阶段!
Grid.ColumnSpacing, Grid.RowSpacing, StackPanel.Spacing are now on UWP preview, all will allow to better acomplish what is requested here.
These properties are currently only available with the Windows 10 Fall Creators Update Insider SDK, but should make it to the final bits!
通常,我使用 Grid 而不是 StackPanel,如下所示:
Usually, I use
Grid
instead ofStackPanel
like this:有时你需要设置 Padding,而不是 Margin 来使项目之间的空间小于默认值
sometimes you need to set Padding, not Margin to make space between items smaller than default