• Django


    新建项目

    
    django-admin startproject mysite
    
    
    • 项目目录
    
    mysite/
    
    manage.py
    
    mysite/
    
    __init__.py
    
    settings.py
    
    urls.py
    
    wsgi.py
    
    
    • 外层的mysite/目录与Django无关,只是你项目的容器,可以任意命名。

    manage.py:一个命令行工具,用于与Django进行不同方式的交互脚本,非常重要!

    • 内层的mysite/目录是真正的项目文件包裹目录,它的名字是你引用内部文件的包名,例如:mysite.urls。

    • mysite/init.py:一个定义包的空文件。

    • mysite/settings.py:项目的主配置文件,非常重要!

    • mysite/urls.py:路由文件,所有的任务都是从这里开始分配,相当于Django驱动站点的内容表格,非常重要!

    • mysite/wsgi.py:一个基于WSGI的web服务器进入点,提供底层的网络通信功能,通常不用关心。

    启动开发服务器

    
    python manage.py runserver
    
    

    创建应用

    
    python manage.py startapp polls
    
    

    编写第一个视图

    在app的view.py文件中添加代码:

    在app目录中新建url.py,并添加代码

    在项目view.py中添加代码。

    • include语法相当于多级路由,它把接收到的url地址去除前面的正则表达式,将剩下的字符串传递给下一级路由进行判断。

    • include的背后是一种即插即用的思想。项目根路由不关心具体app的路由策略,只管往指定的二级路由转发,实现了应用解耦。app所属的二级路由可以根据自己的需要随意编写,不会和其它的app路由发生冲突。app目录可以放置在任何位置,而不用修改路由。这是软件设计里很常见的一种模式。

    
    url(regex, view, kwargs=None, name=None)
    
    
    • url()方法可以接收4个参数,其中2个是必须的:regex和view,以及2个可选的参数:kwargs和name。

    • regex:

    regex是正则表达式的通用缩写,它是一种匹配字符串或url地址的语法。Django拿着用户请求的url地址,在urls.py文件中对urlpatterns列表中的每一项条目从头开始进行逐一对比,一旦遇到匹配项,立即执行该条目映射的视图函数或下级路由,其后的条目将不再继续匹配。因此,url路由的编写顺序非常重要!

    需要注意的是,regex不会去匹配GET或POST参数或域名,例如对于https://www.example.com/myapp/,regex只尝试匹配myapp/。对于https://www.example.com/myapp/?page=3,regex也只尝试匹配myapp/。

    当URLconf模块加载的时候会预先编译正则表达式,因此它的匹配搜索速度非常快,你通常感觉不到。

    • view:

    view指的是处理当前url请求的视图函数。当正则表达式匹配到某个条目时,自动将封装的HttpRequest对象作为第一个参数,正则表达式“捕获”到的值作为第二个参数,传递给该条目指定的视图view。如果是简单捕获,那么捕获值将作为一个位置参数进行传递,如果是命名捕获,那么将作为关键字参数进行传递。

    • kwargs:

    任意数量的关键字参数可以作为一个字典传递给目标视图。

    • name:

    对你的URL进行命名,让你能够在Django的任意处,尤其是模板内显式地引用它。这是一个非常强大的功能,相当于给URL取了个全局变量名,不会将url匹配地址写死。

    • Django 在检查 URL 模式时会把入站 URL 前面的斜线去掉。因此,URL模式中没有前导斜线。

    • 如果有人请求 /hello URL(末尾没有斜线)会发生什么。因为我们指定的 URL 模式要求有末尾的斜线,因此那个 URL 不匹配。然而,默认情况下,如果请求的 URL 不匹配任何 URL 模式,而且末尾没有斜线,那么 Django 会把它重定向到末尾带斜线的 URL。

    • 我们以对象的形式传入 hello 视图函数,而没有调用函数。

    Django处理请求的过程

    1. 请求 /hello/ 。

    2. Django 查看 ROOT_URLCONF 设置,找到根 URL 配置。

    3. Django 比较 URL 配置中的各个 URL 模式,找到与 /hello/ 匹配的那个。

    4. 如果找到匹配的模式,调用对应的视图函数。

    5. 视图函数返回一个 HttpResponse 对象。

    6. Django 把 HttpResponse 对象转换成正确的 HTTP 响应,得到网页。

    动态url

    
    url(r'^time/plus/(d{1,2})/$', hours_ahead)
    
    

    1.URL 模式中放一对圆括号,把想保存的数据括起来,使用圆括号从匹配的文本中捕获数据。

    
    def hours_ahead(request, offset):
    
    try:
    
    offset = int(offset)
    
    except ValueError:
    
    raise Http404()
    
    dt = datetime.datetime.now() + datetime.timedelta(hours=offset)
    
    html = "In %s hour(s), it will be %s.
    
    " % (offset, dt)
    
    return HttpResponse(html)
    
    

    2.offset 是 URL 模式中那对圆括号捕获的字符串。

    秋来凉风起,无限思远人
  • 相关阅读:
    初探JavaScript(一)——也谈元素节点、属性节点、文本节点
    解决Myeclipse下Debug出现Source not found以及sql server中导入数据报错
    Hadoop阅读笔记(六)——洞悉Hadoop序列化机制Writable
    Hadoop阅读笔记(五)——重返Hadoop目录结构
    Hadoop阅读笔记(四)——一幅图看透MapReduce机制
    可视化(番外篇)——在Eclipse RCP中玩转OpenGL
    可视化(番外篇)——SWT总结
    Hadoop阅读笔记(三)——深入MapReduce排序和单表连接
    探秘Tomcat(一)——Myeclipse中导入Tomcat源码
    osgearth将视点绑定到一个节点上
  • 原文地址:https://www.cnblogs.com/lalavender/p/10744892.html
Copyright © 2020-2023  润新知