5

好的,我正在将 HTML 从字符串解析为 PDFCEll。

多亏了这里的一些帮助,它工作得很好。

这就是我的做法。

如何使用外部 css 文件,以便我可以使用类而不是 STYLE=""

public class XhtmlToListHelper : IElementHandler
{
// Generic list of elements
public List<IElement> elements = new List<IElement>();
// Add the item to the list
public void Add(IWritable w)
{
  if (w is WritableElement)
  {
  elements.AddRange(((WritableElement)w).Elements());
  }
}

    string html = "<ul class=\"list\"><li>html 1</li><li>html 2</li><li>html 3</li></ul>";
    using (TextReader sr = new StringReader(html))
    {
        XMLWorkerHelper.GetInstance().ParseXHtml(XhtmlHelper, sr);
    }
    foreach (var element in XhtmlHelper.elements)
    {
        if (element.IsContent())
        {
            PDFCell.AddElement(element);
        }
    }

现在我已经走到了这一步,但是如何把它全部绑起来却让我望而却步。任何帮助都会受到很大的影响。

    HtmlPipelineContext htmlContext = new HtmlPipelineContext(null);
    htmlContext.SetTagFactory(iTextSharp.tool.xml.html.Tags.GetHtmlTagProcessorFactory());
    ICSSResolver cssResolver = XMLWorkerHelper.GetInstance().GetDefaultCssResolver(false);
    cssResolver.AddCssFile(HttpContext.Current.Server.MapPath("~/Templates/css/core.css"), true);
4

1 回答 1

7

如果您在这里查看源代码,您应该会看到如何实现它。基本上,您的三行using块在大小和复杂性上翻了两番:

var XhtmlHelper = new XhtmlToListHelper();
var htmlContext = new HtmlPipelineContext(null);
htmlContext.SetTagFactory(iTextSharp.tool.xml.html.Tags.GetHtmlTagProcessorFactory());
var cssResolver = XMLWorkerHelper.GetInstance().GetDefaultCssResolver(false);
cssResolver.AddCssFile(@"c:\test.css", true);
var pipeline = new CssResolverPipeline(cssResolver, new HtmlPipeline(htmlContext, new ElementHandlerPipeline(XhtmlHelper, null)));//Here's where we add our IElementHandler
var worker = new XMLWorker(pipeline, true);
var parser = new XMLParser();
parser.AddListener(worker);

using (TextReader sr = new StringReader(html)) {
    parser.Parse(sr);
}
于 2013-04-19T13:07:33.013 回答