我从这里重定向:https://github.com/aspnet/AspNetCore/issues/11963
我正在从.Net 4.6转换解决方案的过程中,并且正在查看元数据。
在旧解决方案中,我有一个数据批注元数据提供程序的自定义实现,我已经像这样扩展了它。...
public class ApiMetadataProvider : DataAnnotationsModelMetadataProvider, IDisposable
{
public IResourceProvider ResourceProvider { get; }
public ICoreDataContext CoreDb { get; }
public ApiMetadataProvider(IResourceProvider resourceProvider, ICoreDataContext core)
{
ResourceProvider = resourceProvider;
CoreDb = core;
}
protected override ModelMetadata CreateMetadata(
IEnumerable<Attribute> attributes,
Type containerType,
Func<object> modelAccessor,
Type modelType,
string propertyName)
{
ModelMetadata modelMetadata = base.CreateMetadata(
attributes,
containerType,
modelAccessor,
modelType,
propertyName);
Type serverType = (modelType == typeof(string))
? typeof(string)
: modelType.ImplementsGenericInterface(typeof(IEnumerable<>)) ?? modelType;
if (serverType.IsGenericType && serverType.Name.StartsWith("Nullable") && typeof(Nullable<>).MakeGenericType(serverType.GenericTypeArguments) == serverType) { serverType = serverType.GenericTypeArguments[0]; }
modelMetadata.AdditionalValues.Add("ServerType", serverType.AssemblyQualifiedName);
SetTemplateHint(modelMetadata);
SetCustomAttributes(attributes, modelMetadata, modelType, propertyName);
SetResourceStrings(modelMetadata);
return modelMetadata;
}
....
}
...这里的关键是我为给定类型提取模型元的基本副本,然后以自己的自定义方式对其进行操作(其中一些在上面的示例中显示)。
我把其余的剪掉了,因为有很多。
最终的结果是,从我自己的基本通用控制器中,我执行了一个看起来像这样的操作...
protected MetadataContainer GetMetadataForType(Type type)
{
return new MetadataContainer(MetaProvider.GetMetadataForType(null, type));
}
然后,管制员通常会以此为基础做出决定。
我正在尝试重现此行为,关键是能够从堆栈中获取定制版本的“最终元数据”(我从中收集:https://github.com/aspnet/Mvc/issues/2522 ...该元数据现在是“供应商链”)。
所以我有几个问题....
如何为给定类型在元信息中添加或删除/更新自定义“属性” /属性? 执行完所有提供程序后,如何获取堆栈视为“最终结果”的元实例? 现有的解决方案通常将此元信息交给客户端JS代码,以允许在浏览器中进行“动态组件构建”,在这种情况下,它具有任何形式的最佳实践,我可以从中收集更多建议(也许你们有博客文章还是让我起步的东西)?