Pojawia się błąd:
Metody rozszerzeń muszą być zdefiniowane w nieogólnej klasie statycznej
Na linii:
public class LinqHelper
Oto klasa pomocnicza, oparta na kodzie Mark Gavells. Jestem naprawdę zdezorientowany, co oznacza ten błąd, ponieważ jestem pewien, że działał dobrze, kiedy go zostawiłem w piątek!
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Linq.Expressions;
using System.Reflection;
/// <summary>
/// Helper methods for link
/// </summary>
public class LinqHelper
{
public static IOrderedQueryable<T> OrderBy<T>(this IQueryable<T> source, string property)
{
return ApplyOrder<T>(source, property, "OrderBy");
}
public static IOrderedQueryable<T> OrderByDescending<T>(this IQueryable<T> source, string property)
{
return ApplyOrder<T>(source, property, "OrderByDescending");
}
public static IOrderedQueryable<T> ThenBy<T>(this IOrderedQueryable<T> source, string property)
{
return ApplyOrder<T>(source, property, "ThenBy");
}
public static IOrderedQueryable<T> ThenByDescending<T>(this IOrderedQueryable<T> source, string property)
{
return ApplyOrder<T>(source, property, "ThenByDescending");
}
static IOrderedQueryable<T> ApplyOrder<T>(IQueryable<T> source, string property, string methodName)
{
string[] props = property.Split('.');
Type type = typeof(T);
ParameterExpression arg = Expression.Parameter(type, "x");
Expression expr = arg;
foreach (string prop in props)
{
// use reflection (not ComponentModel) to mirror LINQ
PropertyInfo pi = type.GetProperty(prop);
expr = Expression.Property(expr, pi);
type = pi.PropertyType;
}
Type delegateType = typeof(Func<,>).MakeGenericType(typeof(T), type);
LambdaExpression lambda = Expression.Lambda(delegateType, expr, arg);
object result = typeof(Queryable).GetMethods().Single(
method => method.Name == methodName
&& method.IsGenericMethodDefinition
&& method.GetGenericArguments().Length == 2
&& method.GetParameters().Length == 2)
.MakeGenericMethod(typeof(T), type)
.Invoke(null, new object[] { source, lambda });
return (IOrderedQueryable<T>)result;
}
}
c#
.net
linq
extension-methods
compiler-errors
Tom Gullen
źródło
źródło
public static class IQueryable<T> where T : MyBaseClass
co również generuje ten błąd.where T : MyBaseClass
Wyrażenie należy na poszczególnych metod bez<T>
od klasy statycznej.this
argumentów metody.jeśli nie masz funkcji statycznych, po prostu pozbądź się słowa kluczowego „this” w argumentach.
źródło
this
słowo kluczowe zakopane w sygnaturach mojej metody. Usunięcie go usunęło błąd.Dodaj słowo kluczowe
static
do deklaracji klasy:źródło
Spróbuj zmienić
do
źródło
Zmień to na
źródło
Obejście problemu dla osób, które mają taki błąd, jak Nathan:
Wydaje się, że kompilator w locie ma problem z tym błędem metody rozszerzenia ... dodanie
static
też mi nie pomogło.Chciałbym wiedzieć, co powoduje błąd?
Ale obejściem tego jest napisanie nowej klasy Extension (nie zagnieżdżonej) nawet w tym samym pliku i przebudowanie.
Stwierdziłem, że ten wątek ma wystarczająco dużo widoków, że warto przekazać (ograniczone) rozwiązanie, które znalazłem. Większość osób prawdopodobnie próbowało dodać „statyczny” przed wyszukaniem rozwiązania w Google! i nigdzie indziej nie widziałem tego obejścia.
źródło
Metoda rozszerzenia powinna znajdować się w klasie statycznej. Więc dodaj swoją metodę rozszerzenia do klasy statycznej.
więc na przykład tak powinno być
źródło
Spróbuj zmienić go na klasę statyczną i odwrotnie. To może rozwiązać problem wizualnego studia narzekającego, gdy jest to fałszywie pozytywne.
źródło
Napotkałem podobny problem, utworzyłem folder „foo” i utworzyłem „klasę” wewnątrz foo, a następnie pojawia się wyżej wymieniony błąd. Jedną z poprawek jest dodanie „static”, jak wspomniano wcześniej, do klasy, która będzie „publiczną klasą statyczną LinqHelper”.
Zakładam, że kiedy tworzysz klasę w folderze foo, traktuje ją jako klasę rozszerzenia, dlatego stosuje się do niej następującą zasadę między innymi:
1) Każda metoda rozszerzenia musi być metodą statyczną
Obejście problemu Jeśli nie chcesz statycznego. Moim obejściem było utworzenie klasy bezpośrednio pod przestrzenią nazw, a następnie przeciągnięcie jej do folderu „foo”.
źródło