InsertHtml
InsertHtml(string)
Infogar en HTML-sträng i dokumentet.
public void InsertHtml(string html)
Parameter | Typ | Beskrivning |
---|---|---|
html | String | En HTML-sträng att infoga i dokumentet. |
Anmärkningar
Du kan använda den här metoden för att infoga ett HTML-fragment eller ett helt HTML-dokument.
Exempel
Visar hur man använder en dokumentbyggare för att infoga HTML-innehåll i ett dokument.
Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);
const string html = "<p align='right'>Paragraph right</p>" +
"<b>Implicit paragraph left</b>" +
"<div align='center'>Div center</div>" +
"<h1 align='left'>Heading 1 left.</h1>";
builder.InsertHtml(html);
// Genom att infoga HTML-kod analyseras formateringen av varje element till motsvarande dokumenttextformatering.
ParagraphCollection paragraphs = doc.FirstSection.Body.Paragraphs;
Assert.AreEqual("Paragraph right", paragraphs[0].GetText().Trim());
Assert.AreEqual(ParagraphAlignment.Right, paragraphs[0].ParagraphFormat.Alignment);
Assert.AreEqual("Implicit paragraph left", paragraphs[1].GetText().Trim());
Assert.AreEqual(ParagraphAlignment.Left, paragraphs[1].ParagraphFormat.Alignment);
Assert.True(paragraphs[1].Runs[0].Font.Bold);
Assert.AreEqual("Div center", paragraphs[2].GetText().Trim());
Assert.AreEqual(ParagraphAlignment.Center, paragraphs[2].ParagraphFormat.Alignment);
Assert.AreEqual("Heading 1 left.", paragraphs[3].GetText().Trim());
Assert.AreEqual("Heading 1", paragraphs[3].ParagraphFormat.Style.Name);
doc.Save(ArtifactsDir + "DocumentBuilder.InsertHtml.docx");
Visar hur man utför en sammankoppling med en anpassad återuppringning som hanterar sammanslagningsdata i form av HTML-dokument.
public void MergeHtml()
{
Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);
builder.InsertField(@"MERGEFIELD html_Title \b Content");
builder.InsertField(@"MERGEFIELD html_Body \b Content");
object[] mergeData =
{
"<html>" +
"<h1>" +
"<span style=\"color: #0000ff; font-family: Arial;\">Hello World!</span>" +
"</h1>" +
"</html>",
"<html>" +
"<blockquote>" +
"<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.</p>" +
"</blockquote>" +
"</html>"
};
doc.MailMerge.FieldMergingCallback = new HandleMergeFieldInsertHtml();
doc.MailMerge.Execute(new[] { "html_Title", "html_Body" }, mergeData);
doc.Save(ArtifactsDir + "MailMergeEvent.MergeHtml.docx");
}
/// <summary>
/// Om kopplingen stöter på ett MERGEFIELD vars namn börjar med prefixet "html_",
/// denna återuppringning analyserar dess sammanslagningsdata som HTML-innehåll och lägger till resultatet till dokumentplatsen för MERGEFIELD.
/// </summary>
private class HandleMergeFieldInsertHtml : IFieldMergingCallback
{
/// <summary>
/// Anropas när en e-postsammanfogning slår samman data till ett MERGEFIELD.
/// </summary>
void IFieldMergingCallback.FieldMerging(FieldMergingArgs args)
{
if (args.DocumentFieldName.StartsWith("html_") && args.Field.GetFieldCode().Contains("\\b"))
{
// Lägg till analyserad HTML-data till dokumentets brödtext.
DocumentBuilder builder = new DocumentBuilder(args.Document);
builder.MoveToMergeField(args.DocumentFieldName);
builder.InsertHtml((string)args.FieldValue);
// Eftersom vi redan har infogat det sammanslagna innehållet manuellt,
// vi behöver inte svara på denna händelse genom att returnera innehåll via "Text"-egenskapen.
args.Text = string.Empty;
}
}
void IFieldMergingCallback.ImageFieldMerging(ImageFieldMergingArgs args)
{
// Göra ingenting.
}
}
Se även
- class DocumentBuilder
- namnutrymme Aspose.Words
- hopsättning Aspose.Words
InsertHtml(string, bool)
Infogar en HTML-sträng i dokumentet.
public void InsertHtml(string html, bool useBuilderFormatting)
Parameter | Typ | Beskrivning |
---|---|---|
html | String | En HTML-sträng att infoga i dokumentet. |
useBuilderFormatting | Boolean | Ett värde som anger om formatering anges iDocumentBuilder används som basformatering för text som importeras från HTML. |
Anmärkningar
Du kan använda den här metoden för att infoga ett HTML-fragment eller ett helt HTML-dokument.
NäruseBuilderFormatting ärfalsk
, DocumentBuilder
formatering ignoreras och formatering av infogade text baseras på standard HTML-formatering. Som ett resultat av detta ser texten ut som den renderas i webbläsare.
NäruseBuilderFormatting ärSann
, formateringen av infogad text baseras påDocumentBuilder
formatering, och texten ser ut som om den infogats medWrite
.
Exempel
Visar hur du använder en dokumentbyggares formatering när du infogar HTML-innehåll.
Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);
// Ställ in en textjustering för byggaren, infoga ett HTML-stycke med en specificerad justering och ett utan.
builder.ParagraphFormat.Alignment = ParagraphAlignment.Distributed;
builder.InsertHtml(
"<p align='right'>Paragraph 1.</p>" +
"<p>Paragraph 2.</p>", useBuilderFormatting);
ParagraphCollection paragraphs = doc.FirstSection.Body.Paragraphs;
// Första stycket har en justering specificerad. När InsertHtml analyserar HTML-koden,
// styckejusteringsvärdet som finns i HTML-koden ersätter alltid dokumentbyggarens värde.
Assert.AreEqual("Paragraph 1.", paragraphs[0].GetText().Trim());
Assert.AreEqual(ParagraphAlignment.Right, paragraphs[0].ParagraphFormat.Alignment);
// Andra stycket har ingen anpassning specificerad. Det kan ha sitt justeringsvärde ifyllt
// av byggarens värde beroende på flaggan vi skickade till InsertHtml-metoden.
Assert.AreEqual("Paragraph 2.", paragraphs[1].GetText().Trim());
Assert.AreEqual(useBuilderFormatting ? ParagraphAlignment.Distributed : ParagraphAlignment.Left,
paragraphs[1].ParagraphFormat.Alignment);
doc.Save(ArtifactsDir + "DocumentBuilder.InsertHtmlWithFormatting.docx");
Se även
- class DocumentBuilder
- namnutrymme Aspose.Words
- hopsättning Aspose.Words
InsertHtml(string, HtmlInsertOptions)
Infogar en HTML-sträng i dokumentet. Tillåter att ange ytterligare alternativ.
public void InsertHtml(string html, HtmlInsertOptions options)
Parameter | Typ | Beskrivning |
---|---|---|
html | String | En HTML-sträng att infoga i dokumentet. |
options | HtmlInsertOptions | Alternativ som används när HTML-sträng infogas. |
Anmärkningar
Du kan använda den här metoden för att infoga ett HTML-fragment eller ett helt HTML-dokument.
Exempel
Visar hur du använder alternativ när du infogar html.
Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);
builder.InsertField(" MERGEFIELD Name ");
builder.InsertParagraph();
builder.InsertField(" MERGEFIELD EMAIL ");
builder.InsertParagraph();
// Som standard infogar "DocumentBuilder.InsertHtml" ett HTML-fragment som slutar med ett HTML-element på blocknivå,
// det stänger normalt det blocknivåelementet och infogar en styckebrytning.
// Som ett resultat visas ett nytt tomt stycke efter det infogade dokumentet.
// Om vi anger "HtmlInsertOptions.RemoveLastEmptyParagraph", kommer de extra tomma styckena att tas bort.
builder.MoveToMergeField("NAME");
builder.InsertHtml("<p>John Smith</p>", HtmlInsertOptions.UseBuilderFormatting | HtmlInsertOptions.RemoveLastEmptyParagraph);
builder.MoveToMergeField("EMAIL");
builder.InsertHtml("<p>jsmith@example.com</p>", HtmlInsertOptions.UseBuilderFormatting);
doc.Save(ArtifactsDir + "MailMerge.RemoveLastEmptyParagraph.docx");
Se även
- enum HtmlInsertOptions
- class DocumentBuilder
- namnutrymme Aspose.Words
- hopsättning Aspose.Words