ASP.net MVC - рендеринг Списка, содержащего различные типы, с другим представлением для каждого типа

Вы можете создать свою собственную очередь задач и передать ее конструктору ThreadPoolExecutor:

int poolSize = 1; // number of threads
BlockingQueue<Runnable> queue = new ArrayBlockingQueue<>();
Executor executor = new ThreadPoolExecutor(poolSize, poolSize, 0L, TimeUnit.MILLISECONDS, queue);

Когда вы очищаете очередь где-то в вашем коде, остальные задачи не будут выполнены:

queue.clear();
5
задан tereško 18 July 2012 в 20:24
поделиться

5 ответов

Самый очевидный способ, который я могу придумать, - это сделать что-то вроде:

    foreach(ISummary summ in listOfISummary) {
    Html.RenderPartial(String.Fomat("~/Views/Shared/{0}Renderer.ascx", summ.GetType.ToString()), summ, ViewData);%>
}

и создать строго типизированное представление с соглашением об именах, например NewsSummaryRenderer.ascx.

Я ожидаю, что вы можете переместить это во вспомогательный метод, но я бы добавил его к одному из существующих помощников с помощью метода расширения, а не помещал его в код позади, как предлагалось ранее.

8
ответ дан 14 December 2019 в 04:46
поделиться

Вы можете поместить вспомогательный метод в программный код представления, а затем сделать что-то вроде:

Type modelType = this.Model.GetType();

if (modelType == typeof(NewsSummary))  this.RenderPartial("newspartial", this.Model as NewsSummary);
else if (modelType == typeof(GigSummary)) this.RenderPartial("gigpartial", this.Model as GigSummary);
0
ответ дан 14 December 2019 в 04:46
поделиться

Льюис на правильном пути. Я бы пошел немного по-другому - если бы оба «виджета» происходили из общего базового класса, который предоставлял информацию об используемых именах представлений. Затем добавьте метод расширения к классу страницы для «виджета рендеринга», который может получить соответствующее представление на месте.

Ознакомьтесь с примером приложения Kona ASP.NET MVC для рабочего примера этой концепции.

0
ответ дан 14 December 2019 в 04:46
поделиться

Я бы создал расширение HtmlHelper, которое сделало бы это. Вот какой-то псевдокод, который шокирующе похож на С # и может действительно работать:

public static void TemplatedList<T>(this HtmlHelper me, IEnumerable<T> items, 
IDictionary<Type, Action<T>> templates)
{
  foreach(var item in items)
  {
    var template = templates[item.GetType()];
    if(template != null) template(item);
  }
}

Я бы использовал его так:

<% HtmlHelper.TemplatedList(ViewData.Model, new Dictionary
  {
    {typeof(GigSummary), x => %>

<div class="gigSummary">
SUP!  GIG ANNOUNCEMENT FOR <%= x.Band %>!!

What:  <%= x.Title %>
When: <%= x.Created %>
Who: <%= x.Author %>
</div>

    <%}
  // add more type/template pairs here
  }); %>
0
ответ дан 14 December 2019 в 04:46
поделиться

Вот простой метод расширения, который вы можете создать для извлечения только нужных вам типов:

public static class Extensions
{
    public static IEnumerable<U> ExtractOfType<U, T>(this IEnumerable<T> list)
        where T : class
        where U : class
    {
        foreach (var item in list)
        {
            if (typeof(U).IsAssignableFrom(item.GetType()))
            {
                yield return item as U;
            }
        }
    }
}

Тест:

public interface IBaseInterface
{
    string Foo { get; }
}

public interface IChildInterface : IBaseInterface
{
    string Foo2 { get; }
}

public interface IOtherChildIntreface : IBaseInterface
{
    string OtherFoo { get; }
}

public class BaseImplementation : IBaseInterface
{
    public string Foo { get { return "Foo"; } }
}

public class ChildImplementation : IChildInterface
{
    public string Foo2 { get { return "Foo2"; } }
    public string Foo { get { return "Foo"; } }
}

public class OtherChildImplementation : IOtherChildIntreface
{
    public string OtherFoo { get { return "OtherFoo"; } }
    public string Foo { get { return "Foo"; } }
}

....

        List<IBaseInterface> b = new List<IBaseInterface>();
        b.Add(new BaseImplementation());
        b.Add(new ChildImplementation());
        b.Add(new OtherChildImplementation());
        b.Add(new OtherChildImplementation());


        foreach (var s in b.ExtractOfType<IOtherChildIntreface, IBaseInterface>())
        {
            Console.WriteLine(s.GetType().Name);
        }

Это позволит получить все элементы в список того производного типа, который вы ищете. Итак, в вашем контроллере передайте весь список представлению. Затем создайте частичные представления, которые принимают IEnumerable того типа, который требуется частичному, и в своем основном представлении вызовите этот метод расширения и передайте результат этим отдельным частичным представлениям.

0
ответ дан 14 December 2019 в 04:46
поделиться
Другие вопросы по тегам:

Похожие вопросы: