• Python Django框架笔记(三):django工作方式简单说明和创建用户界面


    (一)  说明

    简单说明下django的工作方式,并举2个例子。

    (二)  Django工作方式

    假定我们有下面这些文件 ,这里在前2篇的基础上增加了 templates目录(存放html文件) 和static目录(存放图片JS、css等)

    (三)   实现一个完整的用户界面

    #假设已经创建好了项目和应用。下面URLconf和视图函数没什么先后关系,根据自己喜好,你可以先写视图函数,也可以先定义URLconf。

    有下面几个步骤

    (1)   创建模型

    (2)   定义项目的URLconf(mysite/mysite/urls.py文件)这部分一个应用只要定义一次就够了

    (3)   定义应用的URLconf(mysite/blog/urls.py)

    (4)   实现URLconf对应的视图函数(同时在创建模板文件(mysite/blog/ templates目录下,其实就是html文件,不过就是用django的模板语言去写罢了,当然,也可以存在纯html代码,django的模板通常就是用来自动生成html代码的))

     (四)  例子:实现代码(博客主页面)

    (1)   创建模型blog/models.py(创建模型后,肯定要生成表结构的,这个就不说了,不知道的可以去看我django笔记的上一篇)

    1 from django.db import models
    2 # Create your models here.
    3 #模型(博客信息的模型,类似博客园随笔那种,包括标题、正文内容及创建时间)
    4 class BlogPost(models.Model):
    5     title = models.CharField(max_length=150)
    6     body = models.TextField()
    7     timestamp = models.DateTimeField()

    (2)   定义项目的URLconf(mysite/mysite/urls.py文件)这部分一个应用只要定义一次就够了

    from django.contrib import admin
    from django.urls import path,include,re_path
    
    urlpatterns = [
        #使用path时第一参数写什么,实际就是什么,第二个参数和re_path是一样的
        path('admin/', admin.site.urls),
        #使用re_path时,第一个参数是正则表达式对象,第二个参数要不就是匹配这个url模式的views函数,要不就是include()指向另一个URLconf
        #使用include时,例如http://localhost:8000/blog/login/,函数会移除。。。blog/,然后把login/传给应用的urls.py文件
        re_path(r'^blog/',include('blog.urls')),
    ]

    (3)   定义应用的URLconf(mysite/blog/urls.py)

    #urls.py
    from django.urls import path,re_path
    from . import views
    
    urlpatterns = [
        #博客主页面,这个可以理解为指向 http://localhost:8000/blog/的请求,都由views.py的archive函数处理
        re_path(r'^$',views.archive),]

    (4)   实现URLconf对应的视图函数mysite/blog/views.py(同时在创建模板文件(mysite/blog/ templates目录下,其实就是html文件,不过就是用django的模板语言去写罢了,当然,也可以存在纯html代码,django的模板通常就是用来自动生成html代码的))

    1 from django.shortcuts import render
    2 from blog.models import BlogPost
    3 #获取博客信息并渲染到页面上
    4 def archive(request):
    5     #获取 BlogPost的所有数据并按timestamp倒序排序
    6     posts = BlogPost.objects.all().order_by('-timestamp')[:10]
    7     #return render_to_response('archive.html', {'posts': posts,'form':BlogPostForm},RequestContext(request))
    8     return render(request,'archive.html',{'posts': posts,})

    (5)创建模板文件mysite/blog/templates目录下创建html文件(文件在创建视图函数之前可以先创建好,等视图函数写好后再去实现)。为了方便阅读,我移除了所有纯html代码,和base.html的继承,所有只用下面的,看到的界面和我的截图肯定是不一样的。(关于base.html的继承这里就先不说明了,要不有点混乱)

    简单的解释下 1、{%%}是模板标签,用来写for if 、else等(下面的这个for,和纯python的for是差不多的 ),这个标签很多,这里先大概了解就行了

                           2、{{ }}里面的是变量,意思是这里插入这个变量的值

                           3、不难发现posts其实就是views.py的archive函数中 render 中第三个参数的 键值(conetext,类似字典)

    1 {% for post in posts %}
    2      <a href=""><h2>{{ post.title }}</h2></a>
    3       <p>{{ post.body }}</p>
    4       <p>{{ post.timestamp }}</p>
    5        <hr>
    6  {% endfor %}

    登录、新建按钮在最右边,这里显示不全

    (五)  登录页面和登录验证实现代码(步骤是一样的)

    #UTLconf的配置这里就略过了

    (1)模型blog/models.py。相比上面的,这里多了一个 表单LoginPostForm,用来自动生成html代码的。可以在python manage.py shell中测试,具体使用方式参考https://docs.djangoproject.com/en/dev/intro/tutorial02/ 中的说明

     1 from django.db import models
     2 from django import forms
     3 # Create your models here.
     4 
     5 #模型(登录页面模型,包括账户、密码)
     6 class LoginPost(models.Model):
     7     user_account=models.CharField(max_length=150)
     8     user_password=models.CharField(max_length=150)
     9 #表单(登录页面表单,django会根据模型自动生成html代码)
    10 class LoginPostForm(forms.ModelForm):
    11     class Meta:
    12         model=LoginPost
    13         fields = "__all__"
    14         labels={
    15             'user_account':'账户',
    16             'user_password':'密码'
    17         }

    (2)   实现视图函数.

    from django.shortcuts import render
    from datetime import datetime
    from blog.models import BlogPost,BlogPostForm,LoginPost,LoginPostForm
    from django.http import HttpResponseRedirect
    
    #渲染登录页面
    def login(request):
        return render(request,'login.html',{'form':LoginPostForm,})
    #登录验证,用户名、密码正确则重定向到blog页面
    def login_verification(request):
        if request.method == 'POST':
            #获取用户提交的账户及密码信息
            user_account = request.POST.get('user_account')
            user_password = request.POST.get('user_password')
            #将账户和密码和数据库中的数据进行对比,true则重定向到blog页面
            for l in LoginPost.objects.all():
                if user_account ==l.user_account and user_password==l.user_password:
                    return HttpResponseRedirect('/blog/')

    (3)模板(同样这里也移除了一部分代码),下面的第四行{{ form }} ,其实就是视图函数login()render 第三个参数的键值 (LoginPostForm会自动生成html代码)

     1 <form action="/blog/check/" method="post">{% csrf_token %}
     2     <table align="center">
     3         <tr >
     4             <td style=" 20px;height: 300px"  >{{ form }}</td>
     5             <td >
     6                 <input type=submit value="登录" >
     7             </td>
     8             <td >
     9                 <input type=button value="注册" >
    10             </td>
    11         </tr>
    12     </table>
    13 </form>
    14 <hr>

     

    (六)  分享一个简单的代码(感兴趣可以参考下,上面模板没有贴出来的部分,里面都有)

    https://pan.baidu.com/s/1yIT7gRfFFWZhNRxL_qQaMw

    主要实现下面3个功能:

    (1)        展现博客信息的主页面

    (2)        实现登录验证(注册功能没实现,所以直接插数据到数据库里面)

    (3)        创建博客并提交到数据库

    (七)Oracle 的存储过程(批量插入数据看效果。当然也可以用其他方式,比如python manage.py shell 中创建具体的对象去插入,或者直接连数据库,用个for 循环去插入等)

     1 create or replace procedure add_data
     2 as
     3   the_num number(11);
     4   title  varchar(255);
     5   bd    clob;
     6 begin
     7   title := 'Web开发除了全部从新写起,还可以在其他人已有的基础上进行开发';
     8   bd :='Web开发除了全部从新写起,还可以在其他人已有的基础上进行开发,简化开发流程。这些Web开发环境统称为Web框架,其目标是帮助开发者简化工作,如提供一些功能来完成一些通用任务,或提供一些资源来用于降低创建、更新、执行或扩展应用的工作量。
     9 Python Web框架既可以是单个或多个子组件,也可以是一个完整的全栈系统。术语“全栈”表示可以开发Web应用所有阶段和层次的代码。框架可以提供所有相关的服务,如Web 服务器、数据库ORM、模板和所有需要的中间件hook。有些还提供了JavaScript库。Django就是这当中一个广为人知的Web框架。';
    10   for i in 1..100 loop
    11     the_num :=i;
    12     insert into Blog_Blogpost values(the_num,title||to_char(the_num),bd||to_char(the_num), sysdate);
    13   end loop;
    14   commit;
    15 end;

    存储过程创建好后,用下面的执行就行了

    1 begin
    2   add_data();
    3 end;

  • 相关阅读:
    poj 1904 King's Quest
    【BZOJ】1051: [HAOI2006]受欢迎的牛
    hdu 2767 Proving Equivalences
    hdu 3234 Exclusive-OR
    poj 1988 Cube Stacking
    poj 1733 Parity game
    hdu 3047 Zjnu Stadium 带权并查集
    poj 1182 食物链 种类并查集
    HDU 3749 Financial Crisis
    【BZOJ】1046 : [HAOI2007]上升序列
  • 原文地址:https://www.cnblogs.com/simple-free/p/8996553.html
Copyright © 2020-2023  润新知