我在CMS的媒体部分有很多图片。我想知道获取图像列表及其文件大小的最佳方法是什么?
是否可以更好地操作数据库中的xml字符串或在CMS前端添加列?
答案 0 :(得分:3)
更新的答案:
更快更好的递归解决方案:
<ul id="imageList">
@foreach (var item in Umbraco.TypedMediaAtRoot()) {
@ShowMediaItems(item)
}
</ul>
@helper ShowMediaItems(IPublishedContent media) {
if (media.Descendants().Any(p => p.DocumentTypeAlias != "Folder") && media.DocumentTypeAlias == "Folder") {
<ul>
@foreach (var child in media.Children) {
@ShowMediaItems(child)
}
</ul>
} else if (media.DocumentTypeAlias == "Image") {
<li>Image url: @media.Url - Size: @(media.GetPropertyValue<int>("umbracoBytes"))</li>
}
}
它会尽可能地深入并且速度更快。我为每个级别添加了一个新的ul列表,但你可以摆脱它。
原始回答:
这很有用,在处理大量图片时效果会很慢但是如果你需要自己获取一个列表(就像在一次性事物中那样),那么它应该可以完成这项工作:
<ul>
@foreach (var item in Umbraco.TypedMediaAtRoot())
{
//Level 1
if (item.DocumentTypeAlias == "Folder")
{
//Level 2
foreach (var item2 in Umbraco.TypedMedia(item.Id).Children)
{
if (item2.DocumentTypeAlias == "Folder")
{
//Level 3
foreach (var item3 in Umbraco.TypedMedia(item2.Id).Children)
{
if (item3.DocumentTypeAlias == "Folder")
{
//Level 3
//etc..
}
else if (item3.DocumentTypeAlias == "Image")
{
<li>Image url: @item3.Url - Size: @(item3.GetPropertyValue<int>("umbracoBytes"))</li>
}
}
}
else if (item2.DocumentTypeAlias == "Image")
{
<li>Image url: @item2.Url - Size: @(item2.GetPropertyValue<int>("umbracoBytes"))</li>
}
}
}
else if (item.DocumentTypeAlias == "Image")
{
<li>Image url: @item.Url - Size: @(item.GetPropertyValue<int>("umbracoBytes"))</li>
}
}
</ul>
根据您在媒体部分中获得的文件夹数量,您可以根据自己的喜好尽可能深入。
请参阅代码中的注释。级别1是根媒体文件夹,级别2是根目录下的文件夹,依此类推。
我刚刚在我当地的Umbraco实例上进行了测试,但它确实有效。
关于大小,它们以字节为单位,因此您可以使用GetPropertyValue(“umbracoBytes”)进行自己的计算