Comment

Comment class

表示评论文本的容器。

要了解更多信息,请访问使用评论文档文章。

public sealed class Comment : InlineStory

构造函数

姓名描述
Comment(DocumentBase)初始化一个新实例Comment类.
Comment(DocumentBase, string, string, DateTime)初始化一个新实例Comment类.

特性

姓名描述
Ancestor { get; }返回父级Comment目的。退货无效的获取顶级评论。
Author { get; set; }返回或设置评论的作者姓名。
Count { get; }获取此节点的直接子节点的数量。
CustomNodeId { get; set; }指定自定义节点标识符。
DateTime { get; set; }获取发表评论的日期和时间。
virtual Document { get; }获取该节点所属的文档。
Done { get; set; }获取或设置指示评论已标记为完成的标志。
FirstChild { get; }获取节点的第一个子节点。
FirstParagraph { get; }获取故事中的第一段。
Font { get; }提供对此对象的锚字符的字体格式的访问。
HasChildNodes { get; }返回真的如果该节点有任何子节点.
Id { get; }获取评论标识符。
Initial { get; set; }返回或设置与特定评论关联的用户的姓名缩写。
override IsComposite { get; }返回真的因为该节点可以有子节点。
IsDeleteRevision { get; }如果在启用更改跟踪时在 Microsoft Word 中删除了此对象,则返回 true。
IsInsertRevision { get; }如果在启用更改跟踪的情况下将此对象插入到 Microsoft Word 中,则返回 true。
IsMoveFromRevision { get; }返回真的如果启用更改跟踪时在 Microsoft Word 中移动(删除)此对象。
IsMoveToRevision { get; }返回真的如果在启用更改跟踪的情况下在 Microsoft Word 中移动(插入)此对象。
LastChild { get; }获取节点的最后一个子节点。
LastParagraph { get; }获取故事的最后一段。
NextSibling { get; }获取紧随该节点的下一个节点。
override NodeType { get; }返回Comment.
Paragraphs { get; }获取故事直接子级的段落集合。
ParentNode { get; }获取此节点的直接父节点。
ParentParagraph { get; }检索父级Paragraph此节点的.
PreviousSibling { get; }获取紧邻此节点之前的节点。
Range { get; }返回一个Range表示此节点中包含的文档部分的对象。
Replies { get; }返回的集合Comment指定注释的直接子对象的对象。
override StoryType { get; }返回Comments.
Tables { get; }获取作为故事的直接子级的表的集合。

方法

姓名描述
override Accept(DocumentVisitor)接受访客。
AddReply(string, string, DateTime, string)添加对此评论的回复。
AppendChild(Node)将指定节点添加到该节点的子节点列表的末尾。
Clone(bool)创建节点的副本。
CreateNavigator()创建可用于遍历和读取节点的导航器。
EnsureMinimum()如果最后一个子级不是段落,则创建并附加一个空段落。
GetAncestor(NodeType)获取指定的第一个祖先NodeType.
GetAncestor(Type)获取指定对象类型的第一个祖先。
GetChild(NodeType, int, bool)返回与指定类型匹配的第 N 个子节点。
GetChildNodes(NodeType, bool)返回与指定类型匹配的子节点的实时集合。
GetEnumerator()为该节点的子节点上的每个样式迭代提供支持。
override GetText()获取此节点及其所有子节点的文本。
IndexOf(Node)返回子节点数组中指定子节点的索引。
InsertAfter(NodeNode)在指定的引用节点之后立即插入指定的节点。
InsertBefore(NodeNode)在指定的引用节点之前插入指定的节点。
NextPreOrder(Node)根据先序树遍历算法获取下一个节点。
PrependChild(Node)将指定节点添加到该节点的子节点列表的开头。
PreviousPreOrder(Node)根据先序树遍历算法获取前一个节点。
Remove()将自身从父级中删除。
RemoveAllChildren()删除当前节点的所有子节点。
RemoveAllReplies()删除对此评论的所有回复。
RemoveChild(Node)删除指定的子节点。
RemoveReply(Comment)删除对此评论的指定回复。
RemoveSmartTags()删除所有SmartTag当前节点的后代节点.
SelectNodes(string)选择与 XPath 表达式匹配的节点列表。
SelectSingleNode(string)选择第一个Node与 XPath 表达式匹配。
SetText(string)这是一种方便的方法,可以轻松设置评论文本。
ToString(SaveFormat)将节点的内容导出为指定格式的字符串。
ToString(SaveOptions)使用指定的保存选项将节点的内容导出到字符串中。

评论

注释是锚定到文本区域或文本中的位置的注释。 注释可以包含任意数量的块级内容。

如果一个Comment对象单独出现,注释锚定到 的位置Comment目的。

要将注释锚定到文本区域,需要三个对象:Comment, CommentRangeStartCommentRangeEnd 。所有三个对象都需要共享相同的 Id价值。

Comment是一个内联级节点并且只能是Paragraph

Comment可以包含ParagraphTable子节点。

例子

演示如何向段落添加注释。

Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);
builder.Write("Hello world!");

Comment comment = new Comment(doc, "John Doe", "JD", DateTime.Today);
builder.CurrentParagraph.AppendChild(comment);
builder.MoveTo(comment.AppendChild(new Paragraph(doc)));
builder.Write("Comment text.");

Assert.AreEqual(DateTime.Today, comment.DateTime);

 // 在Microsoft Word中,我们可以在文档正文中右键单击该注释进行编辑,或者回复。
doc.Save(ArtifactsDir + "InlineStory.AddComment.docx");

演示如何向文档添加评论,然后回复它。

Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);

Comment comment = new Comment(doc, "John Doe", "J.D.", DateTime.Now);
comment.SetText("My comment.");

// 将注释放置在文档正文中的节点处。
// 该注释将显示在其段落的位置,
// 页面右侧边距之外,并用虚线将其与其段落连接起来。
builder.CurrentParagraph.AppendChild(comment);

// 添加回复,该回复将显示在其父评论下方。
comment.AddReply("Joe Bloggs", "J.B.", DateTime.Now, "New reply");

// 评论和回复都是Comment节点。
Assert.AreEqual(2, doc.GetChildNodes(NodeType.Comment, true).Count);

// 不回复其他评论的评论是“顶级”。他们没有祖先的评论。
Assert.Null(comment.Ancestor);

// 回复有一个祖先顶级评论。
Assert.AreEqual(comment, comment.Replies[0].Ancestor);

doc.Save(ArtifactsDir + "Comment.AddCommentWithReply.docx");

也可以看看