Django模板在开发服务器上无法正确呈现

时间:2011-05-25 01:57:29

标签: django django-templates

当使用开发服务器以及视图和模板html文件(两者似乎都正确格式化)时,Django的服务器不会使模板中的html成为网页的源代码,而是应该如此它似乎只是渲染模板,好像它是我想要在页面上显示的东西。所以它似乎创建了它自己的html,我的模板文件是应该打印的文本。例如,以下是在开发服务器上运行时来自网页的视图和模板以及生成的源代码。

查看:

def start(request, ampCode):
t = get_template('code_user.html')
c = Context({'user_code': ampCode})
html = t.render(c)
return HttpResponse(html)

模板:

{% extends "base_code_user.html" %}

{% block title %} This is the title {% endblock %}

{% block body %}

<b> {{user_code}} </b>

{% endblock %}

其他模板扩展的其他模板:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<title> {% block title %}  {% endblock %} </title>
</head>

<body>
    {% block body %} {% endblock %}
</body>

</html>

产生的源代码:

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta http-equiv="Content-Style-Type" content="text/css">
<title></title>
<meta name="Generator" content="Cocoa HTML Writer">
<meta name="CocoaVersion" content="1038.35">
<style type="text/css">
p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px Courier}
p.p2 {margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px Courier; min-height: 14.0px}
span.Apple-tab-span {white-space:pre}
</style>

</head>
<body>
<p class="p1"><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta http-equiv="Content-Style-Type" content="text/css">
<title></title>
<meta name="Generator" content="Cocoa HTML Writer">
<meta name="CocoaVersion" content="1038.35">
<style type="text/css">
p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px Courier}
p.p2 {margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px Courier; min-height: 14.0px}
span.Apple-tab-span {white-space:pre}
</style>

</head>
<body>
<p class="p1">&lt;!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"</p>
<p class="p1"><span class="Apple-converted-space">  </span>"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"&gt;</p>
<p class="p1">&lt;html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"&gt;</p>
<p class="p1"><span class="Apple-converted-space">    </span>&lt;head&gt;</p>
<p class="p1"><span class="Apple-tab-span"> </span>&lt;title&gt;  This is the title  &lt;/title&gt;</p>

<p class="p1"><span class="Apple-converted-space">    </span>&lt;/head&gt;</p>
<p class="p2"><br></p>
<p class="p1"><span class="Apple-tab-span"> </span>&lt;body&gt;</p>
<p class="p1"><span class="Apple-tab-span"> </span><span class="Apple-tab-span">    </span></p>
<p class="p2"><br></p>
<p class="p1"><span class="Apple-tab-span"> </span>&lt;b&gt; AAAAAA &lt;/b&gt;</p>

<p class="p2"><br></p>
<p class="p1"></p>
<p class="p1"><span class="Apple-tab-span"> </span>&lt;/body&gt;</p>
<p class="p2"><br></p>
<p class="p1">&lt;/html&gt;</p>
</body>
</html>

也许我只是不了解模板系统的功能并且它可能正常工作,但我的印象是,模板中的任何内容都将成为页面的最终源代码。任何可能导致这种情况的帮助都会有所帮助。感谢

1 个答案:

答案 0 :(得分:0)

修改

当我在django项目中尝试你的确切示例时,它适用于我(相同的视图名称,相同的模板名称)。输出(假设ampCode为3):

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<title>  This is the title  </title>
</head>

<body>


<b> 3 </b>


</body>

</html>

我的猜测是你的问题在其他地方,而不是在你的代码示例中找到。也许你的URL conf指向一个完全不同的视图有问题?

上一个回答:

在您的视图中,将mimetype添加到HttpResponse

return HttpResponse(html, mimetype='text/html')

如果不是,默认情况下会将其解释为text/plain,因此无法正确呈现html。

如果您想在渲染模板时缩短时间,可以使用响应快捷方式。看看Django shortcut functions