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="width: 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;

 

posted @ 2018-05-05 22:44  free赖权华  阅读(1283)  评论(0编辑  收藏  举报