DataMemberAttribute.EmitDefaultValue Egenskap

Definition

Hämtar eller anger ett värde som anger om standardvärdet för ett fält eller en egenskap ska serialiseras.

public:
 property bool EmitDefaultValue { bool get(); void set(bool value); };
public bool EmitDefaultValue { get; set; }
member this.EmitDefaultValue : bool with get, set
Public Property EmitDefaultValue As Boolean

Egenskapsvärde

trueom standardvärdet för en medlem ska genereras i serialiseringsströmmen. annars . false Standardvärdet är true.

Exempel

I följande exempel visas egenskapen EmitDefaultValue inställd false på för olika fält.

[DataContract]
public class Employee
{
    // The CLR default for as string is a null value.
    // This will be written as <employeeName xsi:nill="true" />
    [DataMember]
    public string EmployeeName = null;

    // This will be written as <employeeID>0</employeeID>
    [DataMember]
    public int employeeID = 0;

    // The next three will not be written because the EmitDefaultValue = false.
    [DataMember(EmitDefaultValue = false)]
    public string position = null;
    [DataMember(EmitDefaultValue = false)]
    public int salary = 0;
    [DataMember(EmitDefaultValue = false)]
    public int? bonus = null;

    // This will be written as <targetSalary>57800</targetSalary>
    [DataMember(EmitDefaultValue = false)]
    public int targetSalary = 57800;
}
<DataContract()>  _
Public Class Employee
    ' The CLR default for as string is a null value.
    ' This will be written as <employeeName xsi:nil="true" />
    <DataMember()>  _
    Public employeeName As String = Nothing
    
    ' This will be written as <employeeID>0</employeeID>
    <DataMember()>  _
    Public employeeID As Integer = 0
    
    ' The next two will not be written because the EmitDefaultValue = false.
    <DataMember(EmitDefaultValue := False)> Public position As String = Nothing
    <DataMember(EmitDefaultValue := False)> Public salary As Integer = 0

    ' This will be written as <targetSalary>555</targetSalary> because 
    ' the 555 does not match the .NET default of 0.
    <DataMember(EmitDefaultValue := False)> Public targetSalary As Integer = 555
End Class

Kommentarer

I .NET Framework har typer ett begrepp med standardvärden. För alla referenstyper är nullstandardvärdet till exempel , och för en heltalstyp är det 0. Ibland är det önskvärt att utelämna en datamedlem från serialiserade data när den är inställd på standardvärdet. För att göra detta anger du EmitDefaultValue egenskapen till false (det är true som standard).

Note

Att ställa in egenskapen på EmitDefaultValuefalse är inte en rekommenderad metod. Det bör endast göras om det finns ett specifikt behov av att göra det (till exempel för samverkan eller för att minska datastorleken).

Gäller för