Aspose.Words for C ++ 是一種高級Word文檔處理API,用於執行各類文檔處理任務。API直接在您本身的C ++應用程序中提供文檔格式化,操做,郵件合併,水印和更多功能,而無需Microsoft Word。API支持大多數Microsoft Word格式進行處理。數據庫
近期更新了Aspose.Words for C ++ v19.10,容許在同一項目中使用多個Aspose產品,在Skia上實現渲染引擎以提升渲染的質量和穩定性,具體更新內容同Aspose.Words for .Net。bash
Aspose.Words for C ++與其等效的.NET版本的API相比有一些差別:app
本文將爲你們介紹一個有趣的的功能——在Word文檔中建立重複節內容控件。ui
重複部份內容控件容許重複其中包含的內容。爲此,SdtType枚舉類型提供了RepeatingSectionItem屬性。下面的代碼示例演示如何將Word文檔中的重複節內容控件綁定到表。加密
System::SharedPtr<Document> doc = System::MakeObject<Document>();
System::SharedPtr<DocumentBuilder> builder = System::MakeObject<DocumentBuilder>(doc);
System::SharedPtr<CustomXmlPart> xmlPart = doc->get_CustomXmlParts()->Add(u"Books", u"<books><book><title>Everyday Italian</title><author>Giada De Laurentiis</author></book><book><title>Harry Potter</title><author>J K. Rowling</author></book><book><title>Learning XML</title><author>Erik T. Ray</author></book></books>"); System::SharedPtr<Table> table = builder->StartTable(); builder->InsertCell(); builder->Write(u"Title"); builder->InsertCell(); builder->Write(u"Author"); builder->EndRow(); builder->EndTable(); System::SharedPtr <StructuredDocumentTag> repeatingSectionSdt = System::MakeObject<StructuredDocumentTag>(doc, SdtType::RepeatingSection, MarkupLevel::Row); repeatingSectionSdt->get_XmlMapping()->SetMapping(xmlPart, u"/books[1]/book", u""); table->AppendChild(repeatingSectionSdt); System::SharedPtr <StructuredDocumentTag> repeatingSectionItemSdt = System::MakeObject<StructuredDocumentTag>(doc, SdtType::RepeatingSectionItem, MarkupLevel::Row); repeatingSectionSdt->AppendChild(repeatingSectionItemSdt); System::SharedPtr<Row> row = System::MakeObject<Row>(doc); repeatingSectionItemSdt->AppendChild(row); System::SharedPtr <StructuredDocumentTag> titleSdt = System::MakeObject<StructuredDocumentTag>(doc, SdtType::PlainText, MarkupLevel::Cell); titleSdt->get_XmlMapping()->SetMapping(xmlPart, u"/books[1]/book[1]/title[1]", u""); row->AppendChild(titleSdt); System::SharedPtr <StructuredDocumentTag> authorSdt = System::MakeObject<StructuredDocumentTag>(doc, SdtType::PlainText, MarkupLevel::Cell); authorSdt->get_XmlMapping()->SetMapping(xmlPart, u"/books[1]/book[1]/author[1]", u""); row->AppendChild(authorSdt); doc->Save(outputDataDir + u"Document.docx");複製代碼
「 Aspose.Words for C ++」 API如今提供了一種方法CustomDocumentProperties.addLinkToContent(String,String)來建立新的「連接至內容」自定義文檔屬性,該屬性將返回新建立的屬性對象;若是連接源無效,則返回null。下面的代碼示例演示如何配置到內容定製屬性的連接。spa
System::SharedPtrdoc = System::MakeObject(inputDataDir + u"test.docx"); // Retrieve a list of all custom document properties from the file. System::SharedPtrcustomProperties = doc->get_CustomDocumentProperties(); // Add linked to content property. System::SharedPtrcustomProperty = customProperties->AddLinkToContent(u"PropertyName", u"BookmarkName"); // Also, accessing the custom document property can be performed by using the property name. customProperty = customProperties->idx_get(customProperties->IndexOf(u"PropertyName")); // Check whether the property is linked to content. bool isLinkedToContent = customProperty->get_IsLinkToContent(); // Get the source of the property. System::String source = customProperty->get_LinkSource(); // Get the value of the property. System::String value = customProperty->get_Value()->ToString();