Comparteix a través de


Expression.Condition Método

Definición

Crea una clase ConditionalExpression que representa una instrucción condicional.

Sobrecargas

Condition(Expression, Expression, Expression)

Crea una clase ConditionalExpression que representa una instrucción condicional.

Condition(Expression, Expression, Expression, Type)

Crea una clase ConditionalExpression que representa una instrucción condicional.

Condition(Expression, Expression, Expression)

Source:
ConditionalExpression.cs
Source:
ConditionalExpression.cs
Source:
ConditionalExpression.cs

Crea una clase ConditionalExpression que representa una instrucción condicional.

public:
 static System::Linq::Expressions::ConditionalExpression ^ Condition(System::Linq::Expressions::Expression ^ test, System::Linq::Expressions::Expression ^ ifTrue, System::Linq::Expressions::Expression ^ ifFalse);
public static System.Linq.Expressions.ConditionalExpression Condition (System.Linq.Expressions.Expression test, System.Linq.Expressions.Expression ifTrue, System.Linq.Expressions.Expression ifFalse);
static member Condition : System.Linq.Expressions.Expression * System.Linq.Expressions.Expression * System.Linq.Expressions.Expression -> System.Linq.Expressions.ConditionalExpression
Public Shared Function Condition (test As Expression, ifTrue As Expression, ifFalse As Expression) As ConditionalExpression

Parámetros

test
Expression

Objeto Expression en el que se va a establecer la propiedad Test.

ifTrue
Expression

Objeto Expression en el que se va a establecer la propiedad IfTrue.

ifFalse
Expression

Objeto Expression en el que se va a establecer la propiedad IfFalse.

Devoluciones

ConditionalExpression cuya propiedad NodeType es Conditional y Test, IfTrue y IfFalse se establecen en los valores especificados.

Excepciones

test o ifTrue o ifFalse es null.

test.Type no es Boolean.

o bien

ifTrue.Type no es igual que ifFalse.Type.

Ejemplos

En el ejemplo de código siguiente se muestra cómo crear una expresión que representa una instrucción condicional. Si el primer argumento se evalúa como true, se ejecuta el segundo argumento; de lo contrario, se ejecuta el tercer argumento.

// Add the following directive to your file:
// using System.Linq.Expressions;

int num = 100;

// This expression represents a conditional operation.
// It evaluates the test (first expression) and
// executes the iftrue block (second argument) if the test evaluates to true,
// or the iffalse block (third argument) if the test evaluates to false.
Expression conditionExpr = Expression.Condition(
                           Expression.Constant(num > 10),
                           Expression.Constant("num is greater than 10"),
                           Expression.Constant("num is smaller than 10")
                         );

// Print out the expression.
Console.WriteLine(conditionExpr.ToString());

// The following statement first creates an expression tree,
// then compiles it, and then executes it.
Console.WriteLine(
    Expression.Lambda<Func<string>>(conditionExpr).Compile()());

// This code example produces the following output:
//
// IIF("True", "num is greater than 10", "num is smaller than 10")
// num is greater than 10
' Add the following directive to your file:
' Imports System.Linq.Expressions  

Dim num As Integer = 100

' This expression represents a conditional operation; 
' it will evaluate the test (first expression) and
' execute the ifTrue block (second argument) if the test evaluates to true, 
' or the ifFalse block (third argument) if the test evaluates to false.
Dim conditionExpr As Expression = Expression.Condition(
                            Expression.Constant(num > 10),
                            Expression.Constant("n is greater than 10"),
                            Expression.Constant("n is smaller than 10")
                        )

' Print the expression.
Console.WriteLine(conditionExpr.ToString())

' The following statement first creates an expression tree,
' then compiles it, and then executes it.       
Console.WriteLine(
    Expression.Lambda(Of Func(Of String))(conditionExpr).Compile()())

' This code example produces the following output:
'
' IIF("True", "num is greater than 10", "num is smaller than 10")
' num is greater than 10

Comentarios

La Type propiedad del resultante ConditionalExpression es igual a la Type propiedad de ifTrue.

Consulte también

Se aplica a

Condition(Expression, Expression, Expression, Type)

Source:
ConditionalExpression.cs
Source:
ConditionalExpression.cs
Source:
ConditionalExpression.cs

Crea una clase ConditionalExpression que representa una instrucción condicional.

public:
 static System::Linq::Expressions::ConditionalExpression ^ Condition(System::Linq::Expressions::Expression ^ test, System::Linq::Expressions::Expression ^ ifTrue, System::Linq::Expressions::Expression ^ ifFalse, Type ^ type);
public static System.Linq.Expressions.ConditionalExpression Condition (System.Linq.Expressions.Expression test, System.Linq.Expressions.Expression ifTrue, System.Linq.Expressions.Expression ifFalse, Type type);
static member Condition : System.Linq.Expressions.Expression * System.Linq.Expressions.Expression * System.Linq.Expressions.Expression * Type -> System.Linq.Expressions.ConditionalExpression
Public Shared Function Condition (test As Expression, ifTrue As Expression, ifFalse As Expression, type As Type) As ConditionalExpression

Parámetros

test
Expression

Objeto Expression en el que se va a establecer la propiedad Test.

ifTrue
Expression

Objeto Expression en el que se va a establecer la propiedad IfTrue.

ifFalse
Expression

Objeto Expression en el que se va a establecer la propiedad IfFalse.

type
Type

Type en el que se va a establecer la propiedad Type.

Devoluciones

ConditionalExpression cuya propiedad NodeType es Conditional y Test, IfTrue y IfFalse se establecen en los valores especificados.

Comentarios

Este método permite unificar explícitamente el tipo de resultado de la expresión condicional en los casos en los que los tipos de ifTrue expresiones y ifFalse no son iguales. Los tipos de y ifTrueifFalse se deben hacer referencia implícitamente al tipo de resultado. type se permite que sea Void.

Se aplica a