CustomXmlProperty
Содержание
[
Скрывать
]CustomXmlProperty class
Представляет один пользовательский атрибут XML или свойство смарт-тега.
Чтобы узнать больше, посетитеСтруктурированные теги документа или контроль содержимого статья документации.
public class CustomXmlProperty
Конструкторы
Имя | Описание |
---|---|
CustomXmlProperty(string, string, string) | Инициализирует новый экземпляр этого класса. |
Характеристики
Имя | Описание |
---|---|
Name { get; } | Указывает имя пользовательского атрибута XML или свойства смарт-тега. |
Uri { get; set; } | Получает или задает URI пространства имен пользовательского атрибута XML или свойства смарт-тега. |
Value { get; set; } | Получает или задает значение пользовательского атрибута XML или свойства смарт-тега. |
Примечания
Используется как предметCustomXmlPropertyCollection
коллекция.
Примеры
Показывает, как создавать смарт-теги.
public void Create()
{
Document doc = new Document();
// Смарт-тег появляется в документе, когда Microsoft Word распознает часть его текста как некоторую форму данных,
// например, имя, дата или адрес, и преобразует его в гиперссылку, подчеркнутую фиолетовым пунктиром.
SmartTag smartTag = new SmartTag(doc);
// Смарт-теги — это составные узлы, которые полностью содержат распознанный текст.
// Добавьте содержимое в этот смарт-тег вручную.
smartTag.AppendChild(new Run(doc, "May 29, 2019"));
// Microsoft Word может распознать приведенное выше содержимое как дату.
// Смарт-теги используют свойство «Элемент», чтобы отразить тип содержащихся в них данных.
smartTag.Element = "date";
// Некоторые типы смарт-тегов преобразуют свое содержимое в пользовательские свойства XML.
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"));
// Установите для URI смарт-тега значение по умолчанию.
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. "));
// Создайте еще один смарт-тег для биржевого тикера.
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."));
// Распечатываем все смарт-теги в нашем документе с помощью посетителя документа.
doc.Accept(new SmartTagPrinter());
// Старые версии Microsoft Word поддерживают смарт-теги.
doc.Save(ArtifactsDir + "SmartTag.Create.doc");
// Используйте метод «RemoveSmartTags», чтобы удалить все смарт-теги из документа.
Assert.AreEqual(2, doc.GetChildNodes(NodeType.SmartTag, true).Count);
doc.RemoveSmartTags();
Assert.AreEqual(0, doc.GetChildNodes(NodeType.SmartTag, true).Count);
}
/// <summary>
/// Распечатывает посещенные смарт-теги и их содержимое.
/// </summary>
private class SmartTagPrinter : DocumentVisitor
{
/// <summary>
/// Вызывается, когда в документе встречается узел SmartTag.
/// </summary>
public override VisitorAction VisitSmartTagStart(SmartTag smartTag)
{
Console.WriteLine($"Smart tag type: {smartTag.Element}");
return VisitorAction.Continue;
}
/// <summary>
/// Вызывается при завершении посещения узла 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;
}
}
Смотрите также
- пространство имен Aspose.Words.Markup
- сборка Aspose.Words