Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

ASP.NET MVC: Cannot use a lambda expression as an argument to a dynamically dispatched operation

I have a ASP.NET MVC4 Application. My view get a List from my controller. I want to select these list with lambda expression but I get the following error:

Cannot use a lambda expression as an argument to a dynamically dispatched operation without first casting it to a delegate or expression tree type

List<project.Models.LAYER> layers = new List<project.Models.LAYER>();
layers = @Model.layers.Select(x => x.KONT == "EUROPE");

@Model.layers is a List

NOW I TRIED THAT: BUT THE SAME ERROR:

@{
  List<project.Models.LAYER> layers = Model.layers.Where(x => x.KNOT == "EUROPE").ToList();
}
like image 924
alexander-fire Avatar asked Jun 13 '13 09:06

alexander-fire


3 Answers

It looks like you're doing this in your view, which violates the principles of separation of concerns. But this is how you would do it.

@
{
   var layers = Model.layers.Where(x => x.KONT == "EUROPE").ToList();
}

@foreach(var layer in layers)
{
  .....
}

A Better Way

What you should do however is create a method on your Model "GetLayersForLocation" Then your code would look like this:

In Your Model Class

public IEnumerable<Layer> GetLayersForLocation(string location)
{
    return this.layers.Where(x => x.Knot == location);
}

In Your View Code

@foreach(var layer in Model.GetLayersForLocation("EUROPE"))
{
  .....
}

The reason this is better is you can now unit test your code, before you wouldn't be able to because it's just part of your view, but now you can run automated tests to ensure that getting the proper layers is working.

like image 130
nerdybeardo Avatar answered Nov 06 '22 04:11

nerdybeardo


For others, I've notice I get this error in Views when I do not have a strongly typed view, such as if a single character accidentally gets typed before the "@model type" line (and thus the model type declaration is now no longer being made.)

 @model SomeModel
like image 43
Greg Avatar answered Nov 06 '22 05:11

Greg


  1. layers is a List, Model.layers.Select will return an IEnumerable.

  2. If you only want to return layer whose KONT == ‘EUROPE', you should use like following

    layers = @Model.layers.Where(x => x.KNOT == "EUROPE").ToList();
    
like image 33
Jason Li Avatar answered Nov 06 '22 03:11

Jason Li