Skip to content

Xamarin Forms 4.7 支持更简化的 Grid 行列布局写法

Updated: at 08:22,Created: at 00:26

尽管非官方提供的 Grid 行列简化版本特别多,但是在最近这样的简写方法才被合并到了主仓库。整个 Xamarin Forms 都是开源的,任何小伙伴都可以发布自己的私有版本。也因此有很多有趣的小伙伴说,我这么好的功能就是不想放在官方,我只是用的爽就可以了。不过,也有很多小伙伴十分慷慨,我就是要放在官方,让更多的小伙伴用的爽。本文要和大家介绍的是一个用起来爽的功能

我的小伙伴 Morten Nielsen 和我吹水说他有一个提议被合并到了 Xamarin 的官方主仓库里面,可以让 Grid 的行列定义更加简单

让咱先看看原先版本的行列定义是怎样的

<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="1*" />
<ColumnDefinition Width="2*" />
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="*" />
<ColumnDefinition Width="300" />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="1*" />
<RowDefinition Height="Auto" />
<RowDefinition Height="25" />
<RowDefinition Height= "14" />
<RowDefinition Height="20" />
</Grid.RowDefinitions>
<!-- 忽略代码 -->
</Grid>

这是标准版本的 Grid 行列布局定义,上面代码将定义了一个网格,可以看到代码量还是比较多的

而简化之后的版本,可以使用如下定义

<Grid ColumnDefinitions="1*, 2*, Auto, *, 300"
RowDefinitions="1*, Auto, 25, 14, 20">
<!-- 忽略代码 -->
</Grid>

是不是觉得瞬间代码就变少了

这个功能其实已经存在很久了,只是都没有合并到官方项目里面,毕竟这个写法还是有一定的争议的

看起来这个写法不错,那么接下来我要在 WPF 官方开源项目里面顶一下 Morten Nielsen 看看能不能将这样的代码也合并到 WPF 官方开源项目里面

如果能赶上的话,大概可以在 WPF 的 .NET 5 发布,也就是 WPF 5 的时候一起上


知识共享许可协议

原文链接: http://blog.lindexi.com/post/Xamarin-Forms-4.7-%E6%94%AF%E6%8C%81%E6%9B%B4%E7%AE%80%E5%8C%96%E7%9A%84-Grid-%E8%A1%8C%E5%88%97%E5%B8%83%E5%B1%80%E5%86%99%E6%B3%95

本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。 欢迎转载、使用、重新发布,但务必保留文章署名 林德熙 (包含链接: https://blog.lindexi.com ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请与我 联系