This documentation is archived and is not being maintained.

Expression.IfThen Method

Creates a ConditionalExpression that represents a conditional block with an if statement.

Namespace:  System.Linq.Expressions
Assembly:  System.Core (in System.Core.dll)

public static ConditionalExpression IfThen(
	Expression test,
	Expression ifTrue


Type: System.Linq.Expressions.Expression
An Expression to set the Test property equal to.
Type: System.Linq.Expressions.Expression
An Expression to set the IfTrue property equal to.

Return Value

Type: System.Linq.Expressions.ConditionalExpression
A ConditionalExpression that has the NodeType property equal to Conditional and the Test, IfTrue, properties set to the specified values. The IfFalse property is set to default expression and the type of the resulting ConditionalExpression returned by this method is Void.

The following code example shows how to create an expression that represents a conditional block.

// Add the following directive to the file:
// using System.Linq.Expressions;  
bool test = true;

// This expression represents the conditional block.
Expression ifThenExpr = Expression.IfThen(
        typeof(Console).GetMethod("WriteLine", new Type[] { typeof(String) }),
        Expression.Constant("The condition is true.")

// The following statement first creates an expression tree,
// then compiles it, and then runs it.

// This code example produces the following output:
// The condition is true.

.NET Framework

Supported in: 4

.NET Framework Client Profile

Supported in: 4

Windows 7, Windows Vista SP1 or later, Windows XP SP3, Windows Server 2008 (Server Core not supported), Windows Server 2008 R2 (Server Core supported with SP1 or later), Windows Server 2003 SP2

The .NET Framework does not support all versions of every platform. For a list of the supported versions, see .NET Framework System Requirements.