CustomXmlProperty
Contenido
[
Ocultar
]CustomXmlProperty class
Representa un único atributo XML personalizado o una propiedad de etiqueta inteligente.
Para obtener más información, visite elEtiquetas de documentos estructurados o control de contenido artículo de documentación.
public class CustomXmlProperty
Constructores
Nombre | Descripción |
---|---|
CustomXmlProperty(string, string, string) | Inicializa una nueva instancia de esta clase. |
Propiedades
Nombre | Descripción |
---|---|
Name { get; } | Especifica el nombre del atributo XML personalizado o propiedad de etiqueta inteligente. |
Uri { get; set; } | Obtiene o establece el URI del espacio de nombres del atributo XML personalizado o propiedad de etiqueta inteligente. |
Value { get; set; } | Obtiene o establece el valor del atributo XML personalizado o propiedad de etiqueta inteligente. |
Observaciones
Utilizado como elemento de unCustomXmlPropertyCollection
recopilación.
Ejemplos
Muestra cómo crear etiquetas inteligentes.
public void Create()
{
Document doc = new Document();
// Aparece una etiqueta inteligente en un documento y Microsoft Word reconoce una parte de su texto como algún tipo de datos,
// como un nombre, fecha o dirección, y lo convierte en un hipervínculo que muestra un subrayado de puntos de color púrpura.
SmartTag smartTag = new SmartTag(doc);
// Las etiquetas inteligentes son nodos compuestos que contienen el texto reconocido en su totalidad.
// Agregue contenido a esta etiqueta inteligente manualmente.
smartTag.AppendChild(new Run(doc, "May 29, 2019"));
// Microsoft Word puede reconocer el contenido anterior como una fecha.
// Las etiquetas inteligentes utilizan la propiedad "Elemento" para reflejar el tipo de datos que contienen.
smartTag.Element = "date";
// Algunos tipos de etiquetas inteligentes procesan su contenido en propiedades XML personalizadas.
smartTag.Properties.Add(new CustomXmlProperty("Day", string.Empty, "29"));
smartTag.Properties.Add(new CustomXmlProperty("Month", string.Empty, "5"));
smartTag.Properties.Add(new CustomXmlProperty("Year", string.Empty, "2019"));
// Establece el URI de la etiqueta inteligente en el valor predeterminado.
smartTag.Uri = "urn:schemas-microsoft-com:office:smarttags";
doc.FirstSection.Body.FirstParagraph.AppendChild(smartTag);
doc.FirstSection.Body.FirstParagraph.AppendChild(new Run(doc, " is a date. "));
// Crea otra etiqueta inteligente para un ticker bursátil.
smartTag = new SmartTag(doc);
smartTag.Element = "stockticker";
smartTag.Uri = "urn:schemas-microsoft-com:office:smarttags";
smartTag.AppendChild(new Run(doc, "MSFT"));
doc.FirstSection.Body.FirstParagraph.AppendChild(smartTag);
doc.FirstSection.Body.FirstParagraph.AppendChild(new Run(doc, " is a stock ticker."));
// Imprime todas las etiquetas inteligentes en nuestro documento usando un visitante del documento.
doc.Accept(new SmartTagPrinter());
// Las versiones anteriores de Microsoft Word admiten etiquetas inteligentes.
doc.Save(ArtifactsDir + "SmartTag.Create.doc");
// Utilice el método "RemoveSmartTags" para eliminar todas las etiquetas inteligentes de un documento.
Assert.AreEqual(2, doc.GetChildNodes(NodeType.SmartTag, true).Count);
doc.RemoveSmartTags();
Assert.AreEqual(0, doc.GetChildNodes(NodeType.SmartTag, true).Count);
}
/// <summary>
/// Imprime las etiquetas inteligentes visitadas y su contenido.
/// </summary>
private class SmartTagPrinter : DocumentVisitor
{
/// <summary>
/// Se llama cuando se encuentra un nodo SmartTag en el documento.
/// </summary>
public override VisitorAction VisitSmartTagStart(SmartTag smartTag)
{
Console.WriteLine($"Smart tag type: {smartTag.Element}");
return VisitorAction.Continue;
}
/// <summary>
/// Se llama cuando finaliza la visita a un nodo SmartTag.
/// </summary>
public override VisitorAction VisitSmartTagEnd(SmartTag smartTag)
{
Console.WriteLine($"\tContents: \"{smartTag.ToString(SaveFormat.Text)}\"");
if (smartTag.Properties.Count == 0)
{
Console.WriteLine("\tContains no properties");
}
else
{
Console.Write("\tProperties: ");
string[] properties = new string[smartTag.Properties.Count];
int index = 0;
foreach (CustomXmlProperty cxp in smartTag.Properties)
properties[index++] = $"\"{cxp.Name}\" = \"{cxp.Value}\"";
Console.WriteLine(string.Join(", ", properties));
}
return VisitorAction.Continue;
}
}
Ver también
- espacio de nombres Aspose.Words.Markup
- asamblea Aspose.Words