1.Django使用ajax的{{value}}语法赋值,结果为空,
原因是该语法和django自带的模板语言语法是一样的,django在服务器会渲染翻译掉该语法,导致ajax无法渲染;
2.解决方案:
可以使用Ajax的原始语法<%= value %>渲染;这样django的服务器模板语言就无法优先渲染,返回到客户端时,ajax就能正常渲染了。
3.全部代码:
<!DOCTYPE html>
<html lang="en">
{% load static %} {#引入静态文件 阙辉#}
<head>
<meta charset="UTF-8">
<title>QhAjaxMB</title>
{# 1.将模板引擎的库文件引入当前页面#}
<script src="{% static '/js/template-web.js' %}"></script>
</head>
<body>
<div id = "qh_container">
</div>
{#2.准备Ajax 模板文件#}
{#定义Ajax模板#}
<script id="qh_tp01" type="text/html">
{# <h1>{{ qhusername }} {{ qhage }}</h1>#}
<h1><%= qhusername %> <%= qhage %></h1>
</script>
<script type="text/javascript">
// template(模板文件id, 数据);
var qh_json = {qhusername: '阙辉', qhage: 18}
// 渲染模板文件
var qh_html = template('qh_tp01', qh_json);
console.log(qh_html)
document.getElementById("qh_container").innerHTML = qh_html
</script>
</body>
</html>