Parameter Attribute Declaration

The Parameter attribute identifies a public property of the cmdlet class as a cmdlet parameter.

Syntax

[Parameter()]
[Parameter(Named Parameters...)]

Parameters

Mandatory (System.Boolean) Optional named parameter. True indicates the cmdlet parameter is required. If a required parameter is not provided when the cmdlet is invoked, Windows PowerShell prompts the user for a parameter value. The default is false.

ParameterSetName (System.String) Optional named parameter. Specifies the parameter set that this cmdlet parameter belongs to. If no parameter set is specified, the parameter belongs to all parameter sets.

Position (System.Int32) Optional named parameter. Specifies the position of the parameter within a Windows PowerShell command.

ValueFromPipeline (System.Boolean) Optional named parameter. True indicates that the cmdlet parameter takes its value from a pipeline object. Specify this keyword if the cmdlet accesses the complete object, not just a property of the object. The default is false.

ValueFromPipelineByPropertyName (System.Boolean) Optional named parameter. True indicates that the cmdlet parameter takes its value from a property of a pipeline object that has either the same name or the same alias as this parameter. For example, if the cmdlet has a Name parameter and the pipeline object also has a Name property, the value of the Name property is assigned to the Name parameter of the cmdlet. The default is false.

ValueFromRemainingArguments (System.Boolean) Optional named parameter. True indicates that the cmdlet parameter accepts all remaining arguments that are passed to the cmdlet. The default is false.

HelpMessage (System.String) Optional named parameter. Specifies a short description of the parameter. Windows PowerShell displays this message when a cmdlet is run and a mandatory parameter is not specified.

HelpMessageBaseName (System.String) Optional named parameter. Specifies the location where resource identifiers reside. For example, this parameter could specify a resource assembly that contains Help messages that you want to localize.

HelpMessageResourceId (System.String) Optional named parameter.Specifies the resource identifier for a Help message.

DontShow (System.Boolean) Optional named parameter. True indicates that the parameter is hidden from the user for tab expansion and IntelliSense. The default is false.

Remarks

  • For more information about how to declare this attribute, see How to Declare Cmdlet Parameters.

  • A cmdlet can have any number of parameters. However, for a better user experience, limit the number of parameters.

  • Parameters must be declared on public non-static fields or properties. Parameters should be declared on properties. The property must have a public set accessor, and if the ValueFromPipeline or ValueFromPipelineByPropertyName keyword is specified, the property must have a public get accessor.

  • When you specify positional parameters, limit the number of positional parameters in a parameter set to less than five. And, positional parameters do not have to be contiguous. Positions 5, 100, and 250 work the same as positions 0, 1, and 2.

  • When the Position keyword is not specified, the cmdlet parameter must be referenced by its name.

  • When you use parameter sets, note the following:

    • Each parameter set must have at least one unique parameter. Good cmdlet design indicates this unique parameter should also be mandatory if possible. If your cmdlet is designed to be run without parameters, the unique parameter cannot be mandatory.

    • No parameter set should contain more than one positional parameter with the same position.

    • Only one parameter in a parameter set should declare ValueFromPipeline = true.

    • Multiple parameters can define ValueFromPipelineByPropertyName = true.

  • For more information about the guidelines for parameter names, see Cmdlet Parameter Names.

  • The parameter attribute is defined by the System.Management.Automation.ParameterAttribute class.

  • The DontShow parameter has the following side effects:

    • Affects all parameter sets for the associated parameter, even if there's a parameter set in which DontShow is unused.
    • Hides common parameters from tab completion and IntelliSense. DontShow doesn't hide the optional common parameters: WhatIf, Confirm, or UseTransaction.

See Also