zoukankan      html  css  js  c++  java
  • 显示所有主题

    1.URL 模式
    
    node2:/django/mysite/learning_log/learning_log#cat urls.py
    """learning_log URL Configuration
    
    The `urlpatterns` list routes URLs to views. For more information please see:
        https://docs.djangoproject.com/en/1.11/topics/http/urls/
    Examples:
    Function views
        1. Add an import:  from my_app import views
        2. Add a URL to urlpatterns:  url(r'^$', views.home, name='home')
    Class-based views
        1. Add an import:  from other_app.views import Home
        2. Add a URL to urlpatterns:  url(r'^$', Home.as_view(), name='home')
    Including another URLconf
        1. Import the include() function: from django.conf.urls import url, include
        2. Add a URL to urlpatterns:  url(r'^blog/', include('blog.urls'))
    """
    from django.conf.urls import include,url
    from django.contrib import admin
    
    urlpatterns = [
        url(r'^admin/', admin.site.urls),
        url(r'^log/',include('learning_logs.urls',namespace='learning_logs')),
    ]
    
    
    我们只是在用于主页的正则表达式中添加topics/,Django检查请求的URL时.这个模式与这样的URL匹配,
    
    基础URL后面跟着topics,可以在末尾包含斜杠.
    
    
    请求方式:
    http://192.168.137.3:9000/log/topics
    
    
    node2:/django/mysite/learning_log/learning_logs#cat views.py
    # -*- coding: utf-8 -*-
    from __future__ import unicode_literals
    
    from django.shortcuts import render
    from .models import Topic
    
    # Create your views here.
    def index(request):
      return render(request,'learning_logs/index.html')
    
    def topics(request):
       print 'call topics'
       topics = Topic.objects.order_by('date_added')
       context = {'topics':topics}
       return render(request,'learning_logs/topics.html',context)
       
       
    
    我们首先导入了与所需数据相关联的模型。  函数topics()包含一个形参:
    
    Django从服务器那里收到的request对象。
    
    我们定义了一个将要发送给模板的上下文。上下文是一个字典,其中的键是我们将在模板中用来访问数据的名称
    
    而值是我们要发送给模板的数据。
    
    3.模板
    
    显示所有主题的页面的模板接收字典context,以便能够使用topics()提供的数据。
    
    请创建一个文件,将其命名为topics.html,并存储到index.html所在的目录中
    
    node2:/django/mysite/learning_log/learning_logs/templates/learning_logs#cat topics.html 
    {% extends "learning_logs/base.html" %}
    {% block content %}
    <p>Topics</p>
    <ul>
       {% for topic in topics %}
         <li>{{ topic }} </li>
         {% empty %}
         <li>No topics have been added yet.</li>
         {% endfor %}
    </ul>
    {% endblock content %}
    
    
    就像index.html一样,我们首先使用标签{% extends %}来继承base.html,
    
    再开始定义content 块。 这个网页的主体是一个项目列表,其中列出了用户输入的主题。
    
    
    在2处,我们使用了一个相当于for循环的模板标签,它遍历字典context中的列表topics.
    
    模板中使用的代码与Python代码存在一些重要差别;
    
    Python 使用缩进来指出哪些代码行是for循环的组成部分,而在模板中,
    
    每个for循环都必须使用{% endfor %}标签来显示地指出其结束位置。
    
    在循环中,我们要将每个主题转换为一个项目列表项,要在模板中打印变量,需要将变量名用双花括号括起来。
    
    每次循环时,{{topic}}都被替换为topic的当前值
    
    这些花括号不会出现在网页中,他们只是用于告诉Django我们使用了一个模板变量。
    
    HTML标签<li></li>表示一个项目列表项,在标签对<ul></ul>内部
    
    我们使用了模板标签{% empty %},它告诉Django在列表topics为空时该怎么办,这里是打印一条消息,
    
    
    告诉用户还没有添加任何主题。最后两行分别结束for循环
    
    node2:/django/mysite/learning_log/learning_logs/templates/learning_logs#cat base.html
    <p> <a href="{% url 'learning_logs:index' %}">Learning Log</a>
         <a href="{% url 'learning_logs:topics' %}">Topics</a>
    </p>
    {% block content %}{% endblock content %}
    
    http://192.168.137.3:9000/log/topics
    
    
  • 相关阅读:
    你在寻找Vue3移动端项目框架嘛?请看这里
    vue init webpack xxx很慢?办它!
    TypeScript学习2TypeScript基础静态类型和对象类型
    百度地图自定义marker、文本标注
    TypeScript学习1开发环境搭建
    <三>computed 和事件的绑定
    <七>vue脚手架
    <八>vue脚手架项目结构
    <九>组件和路由
    <五>子父组件间的交互
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13348713.html
Copyright © 2011-2022 走看看