Je n'ai pas essayé, mais vous pouvez envisager d' enregistrer vos vues , puis de définir les données de vue pendant le processus d'activation.
Étant donné que les vues sont enregistrées à la volée, la syntaxe d'enregistrement ne vous aide pas à vous connecter à l' Activated
événement, vous devez donc le configurer dans un Module
:
class SetViewBagItemsModule : Module
{
protected override void AttachToComponentRegistration(
IComponentRegistration registration,
IComponentRegistry registry)
{
if (typeof(WebViewPage).IsAssignableFrom(registration.Activator.LimitType))
{
registration.Activated += (s, e) => {
((WebViewPage)e.Instance).ViewBag.Global = "global";
};
}
}
}
Cela pourrait être une de ces suggestions de type "seul outil est un marteau" de ma part; il peut y avoir des moyens plus simples activés par MVC pour y parvenir.
Edit: Autre approche, moins de code - il suffit de l'attacher au contrôleur
public class SetViewBagItemsModule: Module
{
protected override void AttachToComponentRegistration(IComponentRegistry cr,
IComponentRegistration reg)
{
Type limitType = reg.Activator.LimitType;
if (typeof(Controller).IsAssignableFrom(limitType))
{
registration.Activated += (s, e) =>
{
dynamic viewBag = ((Controller)e.Instance).ViewBag;
viewBag.Config = e.Context.Resolve<Config>();
viewBag.Identity = e.Context.Resolve<IIdentity>();
};
}
}
}
Edit 2: Une autre approche qui fonctionne directement à partir du code d'enregistrement du contrôleur:
builder.RegisterControllers(asm)
.OnActivated(e => {
dynamic viewBag = ((Controller)e.Instance).ViewBag;
viewBag.Config = e.Context.Resolve<Config>();
viewBag.Identity = e.Context.Resolve<IIdentity>();
});