gra*_*ntk 5 django twitter-bootstrap weasyprint
所以我有一个非常简单的模板,正在使用 WeasyPrint 进行测试。如果将模板渲染为常规网页,它会渲染得很好。如果我尝试生成 PDF,样式就会消失。只有当我删除引导程序引用时,PDF 才会正确生成。有谁知道为什么在我引入 bootstrap css 文件后样式不起作用?我尝试过一些 Bootstrap3 和 Bootstrap2 文件。提供本地和 CDN 服务。
模板:
<!doctype html>
<html lang="en">
{% load static from staticfiles %}
{% block head %}
<head>
{% block css %}
<link rel="stylesheet" href="{% static "css/bootstrap.min.css" %}">
<link rel="stylesheet" href="{% static "css/main.css" %}">
{% endblock css %}
</head>
{% endblock head %}
<body>
{% block content %}
<div id="content" class="container">
<div id="logo" class="col-md-3">
<img src="{% static "images/logo_small.png" %}">
</div>
<div id="heading" class="col-md-6">
<h1>Packing Slip</h1>
</div>
<div class="col-md-3">
<h2>{{ packslip_id }}</h2>
</div>
</div>
{% endblock %}
</body>
</html>
Run Code Online (Sandbox Code Playgroud)
我的看法:
class WeasyPDF(TemplateView):
template_name = 'jinja2/Shipping/test_pdf.html'
def get(self, request, *args, **kwargs):
packslip_id = kwargs.get('packslip_id')
context= {'packslip_id': packslip_id }
template_string = render_to_string(self.template_name, context)
html = HTML(string=template_string, base_url=request.build_absolute_uri())
main_doc = html.render()
pdf = main_doc.write_pdf()
response = HttpResponse(pdf, content_type='application/pdf')
#Download as attachment
# response['Content-Disposition'] = 'attachment; filename=packslip-{0}.pdf'.format(packslip_id)
# Display in browser
response['Content-Disposition'] = 'filename=packslip-{0}.pdf'.format(packslip_id)
return response
Run Code Online (Sandbox Code Playgroud)
最后是 urls.py 条目
url(r'^weasypdf/(?P<packslip_id>\d+)$', WeasyPDF.as_view(), name='weasypdf'),
Run Code Online (Sandbox Code Playgroud)
我相信你需要将CSS渲染到你的html对象中: html = HTML(string=template_string, base_url=request.build_absolute_uri(), stylesheet="filename.css")
完成后,Weasyprint 会将其渲染为 HTML 对象,以便在 PDF 和 HTML 中显示
| 归档时间: |
|
| 查看次数: |
6328 次 |
| 最近记录: |