Django学习笔记-模板

简单点来说,网站无外乎就是从前端得到数据,数据在后端处理,将数据返回给前端。

这里就不说如何获取前端数据了。

一、数据返回给前端

之前的demo中有一种:

return HttpResponse(u"接收这个请求后,返回的数据")

但是这种基本是用不到了,正常的做法是URL中的name属性和VIEW中render。当然也可能使用JSON等等来实现数据传输。

直接看demo吧,新建的应用叫my_tem,所以网页为my_tem/home.html

views.py

def home(request):
    m_str = u"前台正在接收这个string"
    m_list = ['HTML', 'CSS', 'jQuery', 'Python', 'Django']
    m_dict = {'name': 'zhaoguangyao', 'sex': '男'}
    m_range = [i for i in range(100)]

    return render(request, 'my_tem/home.html', {'m_str': m_str,
                                                'm_list': m_list,
                                                'm_dict': m_dict,
                                                'm_range': m_range})

urls.py

urlpatterns = [
    url(r'^$', xx.home, name='home'),
    url(r'^admin/', admin.site.urls),
]

home.html

<!DOCTYPE html>
<html>
<head>
    <title>zhaoguangyao</title>
</head>
<body>


templates<br>
{{m_str}}<br>
<br>


这是一个list,将要用for循环遍历:<br>
{% for i in m_list %}
{{ i }}<br>
{% endfor %}


<br>
这是一个字典,将要输出字典里的内容:<br>
名字:{{ m_dict.name }}<br>
性别:{{ m_dict.sex }}<br>

<br>
也可以遍历字典:<br>
{% for key, value in m_dict.items %}
{{ key }} : {{ value }}<br>
{% endfor %}


<br>
便利一下1-100,但是这样最后也有逗号:<br>
{% for i in m_range %}
{{ i }},
{% endfor %}<br>
<br>
遍历里面加入判断:<br>
{% for i in m_range %}
{{ i }}{% if forloop.last %}<br>{% else %},{% endif %}
{% endfor %}


<br>
<span style="color: red;">这个就重要了,模板上得到对应的视图</span><br>
{% url 'add' 4 5 %}<br>

<br>
<span style="color: red;">还可以用as语句讲内容区别名,就相当于一个变量,然后就能使用了</span>
{% url 'add' 4 5 as m_url%}
<br>
<a href="{{ m_url }}">连接到:{{ m_url }}</a><br>

<br>
{{ request.user }}
<br>
{% if request.user.is_authenticated %}
    {{ request.user.username }},您好!
{% else %}
    请登录,这里放登陆链接
{% endif %}<br>

{{ request.path }}<br>

{{ request.GET.urlencode }}<br>

{{ request.path }}?{{ request.GET.urlencode }}<br>

<a href="{{ request.path }}?{{ request.GET.urlencode }}&delete=1">
    当前网址加参数 delete
</a>


</body>
</html>

项目做完了,但是好多东西都没有整理出来。比如django与json,ajax等等。

上一篇:Replication--将LSN转换成16进制


下一篇:【SpringBoot2 从0开始】开发世界著名程序体验 springboot