尽管非官方提供的 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 的时候一起上


本文会经常更新,请阅读原文: https://dotnet-campus.github.io//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.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。

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