2016-10-05 2 views
0

Я пытаюсь присвоить значение выражением linq.js. Ламба expresion LINQ будет выглядеть так:Linq to linq.js перевод со значением присваивания

List<SearchSpaceRoom> roomsAvailable = Spaces.Select(s => 
    { 
     s.Available = s.Rooms.Where(r => r.RoomTypeRanges.Any(t => t.Type.ToString() == "Theatre" && t.Min <= 101 && t.Max >= 200)).Count(); 
     return s; 
    }) 
    .ToList(); 

Но я не могу найти способ сделать это, чтобы работать с linq.js. Идея заключается в том, чтобы иметь что-то вроде этого:

var data = eval($('#SpaceJson').val()); 
var results = $.Enumerable.From(data).ToArray(); 
var layout = 'Theatre'; 
var minDelegates = '101'; 
var maxDelegates = '200'; 

results = $.Enumerable.From(results) 
    .Select('{$.Available = $.Rooms.Where($.RoomTypeRanges.Any($.Type == \'' + layout + '\' && $.Min <= \'' + parseInt(minDelegates) + '\' && t.Max >= \'' + parseInt(maxDelegates) + '\')).Count(); return $; }').ToArray(); 

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

Если вам нужна дополнительная информация о выражении: , то необходимо назначить количество комнат, которые соответствуют требованиям людей Min и Max для определенного макета (класс, театр) для каждого места. Основная структура, как:

  1. Одно пространство содержит Комнаты
  2. Один номер содержит различные схемы
  3. Макет содержит максимальное Н. мин люди

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

Спасибо!

EDIT: Я добавить классы здесь

public class SearchSpaceViewModel 
{ 
    public List<SearchSpaceRoom> Spaces { get; set; } 
    public string RoomsJson { get; set; } 
} 

public class SearchSpaceRoom 
{ 
    public List<RoomItem> Rooms { get; set; } 
    public int Available { get; set; } 
    . 
    . 
    . 
} 

public class RoomItem 
{ 
    public List<RoomTypeRange> RoomTypeRanges { get; set; } 
    . 
    . 
    . 

} 

public class RoomTypeRange 
{ 
    public string Type { get; set; } 
    public int Max { get; set; } 
    public int Min { get; set; } 
} 

ответ

0

Просто, чтобы закрыть это, мне удалось это сделать, используя смесь JQuery и linq.js:

function ParseJson() { 
     var data = eval($('#RoomsJson').val()); 
     var results = $.Enumerable.From(data).ToArray(); 
     var layout = 'Theatre'; 
     var intMin = 101; 
     var intMax = 200; 

     $.each(results, function (i, space) { 
      var count = 0; 
      $.each(space.Rooms, function (j, room) { 
       if ($.Enumerable.From(room.RoomTypeRanges).Any('$.Type == \'' + layout + '\' && $.Min <= ' + intMin + ' && $.Max >= ' + intMax)) { 
        count++; 
       } 
      }); 
      space.Available = count; 
     }); 

     return results; 
    } 

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

Смежные вопросы