使用XmlSerializer时,若要保留空标签,需避免属性为null。可通过[XmlElement(IsNullable=true)]保留nil标签,或将null转为空字符串以生成格式。

在 C# 中使用 XmlSerializer 进行 XML 序列化时,如果某个字符串属性为空或为 null,默认情况下该元素会被省略或生成自闭合标签(如
1. 使用 XmlElement 特性指定 IsNullable
通过给属性添加 [XmlElement(IsNullable = true)] 特性,可以让序列化器在值为 null 时保留标签,并输出为 xsi:nil="true" 的格式。虽然这不是纯粹的空标签,但能确保标签存在。
[XmlElement(IsNullable = true)]
public string Name { get; set; }序列化结果:
注意:这需要包含 xsi 命名空间,且表示“null”而非“空字符串”。
2. 将 null 转为空字符串
如果你希望输出
private string _name;
[XmlElement("Name")]
public string Name
{
get => _name ?? "";
set => _name = value;
}或者在构造函数或赋值时统一处理:
public string Name { get; set; } = "";这样即使字段为空,也会生成:
3. 使用 StringWriter 自定义命名空间
避免默认生成的 xmlns:xsi 和 xmlns:xsd,可以自定义 XmlWriterSettings 并清除命名空间。
示例代码:var serializer = new XmlSerializer(typeof(Person));
var settings = new XmlWriterSettings
{
OmitXmlDeclaration = false,
Indent = true
};
using var stringWriter = new StringWriter();
using var xmlWriter = XmlWriter.Create(stringWriter, settings);
serializer.Serialize(xmlWriter, person);
string xml = stringWriter.ToString();
结合属性设置为 "" 后,即可输出干净的空标签。
4. 综合建议
- 若需明确表达“无值”,使用 IsNullable = true,接受
xsi:nil="true"格式。 - 若只需保留空标签结构,将属性值设为 string.Empty 或使用默认值 ""。
- 避免属性为 null 是关键,因为 null 可能导致标签被跳过或变成自闭合。
基本上就这些。只要确保字段不是 null,并合理使用特性,就能在序列化 XML 时保留你想要的空标签格式。










