是否可以在.py文件中生成html并在qweb中呈现?
<openerp>
<data>
<record id="paperformat_time" model="report.paperformat">
<field name="name">Time</field>
<field name="font_size">10</field>
</record>
<report id="time_qweb" model="hr_timesheet_sheet.sheet" string="Time"
report_type="qweb-pdf" name="time.report_time" file="time.report_time" />
<record id="time_qweb" model="ir.actions.report.xml">
<field name="paperformat_id" ref="time.paperformat_time" />
</record>
</data>
</openerp>
qweb
<template id="report_time">
<t t-call="report.html_container">
<t t-foreach="docs" t-as="t">
<span t-esc="t.__compute_html()" />
<div class="page">
<span t-field="t.html_text " />
</div>
</t>
</t>
</template>
.py文件
class Time(models.Model):
_inherit = 'hr_timesheet_sheet.sheet'
html_text = fields.Html(string = 'Html')
@api.one
def _compute_html(self):
html_value = "<h1>TEST</h1>"
html_value += "<h1>TEST 2</h1>"
self.html_text = html_value
例如。
html_value = "<h1> + employee_id.name + "</h1>"
html_value += "<h1> + employee_id.phone + "</h1>"
现在我需要在qweb中放入<div class="page"> put here html_value </div>
现在我将文本保存在数据库中,有什么更好的解决方案吗?................................
答案 0 :(得分:3)
是的,如果你有一个带有html代码的变量,如果你使用t-esc
或t-field
,odoo会把它打印成文本。
如果要渲染它,请使用。 t-row
<div t-raw="doc.some_attribute" > </div>
或
<t t-raw="doc.some_attribute" > </t>
答案 1 :(得分:0)
您可以尝试
<span t-raw="my_html_field"/>
my_html_field是您的html格式数据