1.在pycharm中新建project demo1 添加app01 点击create按钮完成新建
2.在demo项目目录下新建目录static,并在settings.py中追加代码:
1
|
STATICFILES_DIRS = (os.path.join(BASE_DIR, 'static' ),) |
3.在setting.py中添加模板路径:
1
2
3
4
5
6
7
8
9
10
11
12
|
TEMPLATES = [ { 'BACKEND' : '...' , 'DIRS' : [os.path.join(BASE_DIR, 'templates' ),], 'APP_DIRS' : ..., 'OPTIONS' : { 'context_processors' : [ ... ], }, }, ] |
4.学员管理系统数据库设计:
在app01/model.py目录下建立 班级、老师、学生 、老师与班级关联表 四张表:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
# Create your models here. class Classes(models.Model): ''' 班级表 ''' title = models.CharField(max_length = 32 ) a = models.ManyToManyField( 'Teachers' ) class Teachers(models.Model): ''' 老师表 ''' name = models.CharField(max_length = 32 ) class Students(models.Model): username = models.CharField(max_length = 32 ) age = models.IntegerField() gender = models.BooleanField() cs = models.ForeignKey(Classes,on_delete = models.CASCADE) |
在终端Terminal 项目目录下执行数据表更新命令:
1
2
|
python manage.py makemigrations python manage.py migrate |
至此生成了四张数据表,可以在pycharm中,点开右上角的Database面板,然后将项目中templates目录下边的db.sqlite3鼠标拖拽到Database面板下,对新创建的数据表进行查看。
5.学员管理系统之班级管理:
为了方便分别操作班级、老师、学生相关的业务,将app01目录下的views.py 删掉,在app01目录下新建目录views,并在views目录下 新建classes.py teachers.py students.py。
1.在classes.py 中写 get_classes add_classes del_classes edit_classes四个函数,完成对 班级数据 的增删改查:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
from django.shortcuts import render,redirect from app01 import models def get_classes(request): cls_list = models.Classes.objects. all () return render(request, 'get_classes.html' ,{ 'cls_list' :cls_list}) def add_classes(request): if request.method = = 'GET' : return render(request, 'add_classes.html' ) elif request.method = = 'POST' : title = request.POST.get( 'title' ,'') models.Classes.objects.create(title = title) return redirect( '/classes.html' ) def del_classes(request): nid = request.GET.get( 'nid' ,'') models.Classes.objects. filter ( id = nid).delete() return redirect( '/classes.html' ) def edit_classes(request): if request.method = = "GET" : nid = request.GET.get( 'nid' , '') obj = models.Classes.objects.get( id = nid) return render(request, 'edit_classes.html' ,{ 'obj' :obj}) elif request.method = = "POST" : nid = request.POST.get( 'nid' ,'') title = request.POST.get( 'xxoo' ,'') models.Classes.objects. filter ( id = nid).update(title = title) return redirect( '/classes.html' ) |
2.在urls.py 中配置url路由:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
from django.contrib import admin from django.urls import path from app01.views import classes,students,teachers urlpatterns = [ path( 'admin/' , admin.site.urls), path( 'classes.html' , classes.get_classes), path( 'add_classes.html' , classes.add_classes), path( 'del_classes.html' , classes.del_classes), path( 'edit_classes.html' , classes.edit_classes), # path('teachers.html', teachers.get_teachers), # path('students.html', students.get_studernts), ] |
3.在template目录下建立所需的html页面文件:
get_classes.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
DOCTYPE html> < html lang = "en" > < head > < style > tr td{ border:1px solid #000;text-align:center;} </ style > < meta charset = "UTF-8" > < title >Title</ title > </ head > < body > < div > < table > < thead > < tr > < th >ID</ th > < th >名称</ th > < th >操作</ th > </ tr > </ thead > < tbody > {% for row in cls_list %} < tr > < td >{{ row.id }}</ td > < td >{{ row.title }}</ td > < td >< a href = "/del_classes.html?nid={{ row.id }}" rel = "external nofollow" rel = "external nofollow" >删除</ a > |< a href = "/edit_classes.html?nid={{ row.id }}" rel = "external nofollow" rel = "external nofollow" >编辑</ a > </ td > </ tr > {% endfor %} </ tbody > </ table > </ div > < div >< a href = "/add_classes.html" rel = "external nofollow" rel = "external nofollow" >添加</ a > </ div > </ body > </ html > |
add_classes.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<!DOCTYPE html> < html lang = "en" > < head > < meta charset = "UTF-8" > < title >Title</ title > </ head > < body > < form action = "/add_classes.html" method = "post" > {% csrf_token %} < input type = "text" name = "title" > < input type = "submit" value = "提交" > </ form > </ body > </ html > |
edit_classes.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
<!DOCTYPE html> < html lang = "en" > < head > < meta charset = "UTF-8" > < title >Title</ title > </ head > < body > < form method = "post" action = "/edit_classes.html" > {% csrf_token %} < input type = "hidden" name = "nid" value = "{{ obj.id }}" > < input type = "text" name = "xxoo" value = "{{ obj.title }}" > < input type = "submit" value = "提交" > </ form > </ body > </ html > |
6.学员管理系统之学员管理: 1.在students.py 中写 get_students add_students del_students edit_students 四个函数,完成对 学生数据 的增删改查:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
from django.shortcuts import render,redirect from app01 import models def get_students(request): stu_list = models.Students.objects. all () return render(request, 'get_students.html' ,{ 'stu_list' :stu_list}) def add_students(request): if request.method = = 'GET' : cs_list = models.Classes.objects. all () return render(request, 'add_students.html' ,{ 'cs_list' :cs_list}) elif request.method = = 'POST' : u = request.POST.get( 'username' ,'') a = request.POST.get( 'age' ,'') g = request.POST.get( 'gender' ,'') c = request.POST.get( 'cs' ,'') models.Students.objects.create( username = u, age = a, gender = g, cs_id = c ) return redirect( '/students.html' ) def del_students(request): nid = request.GET.get( 'nid' , '') models.Students.objects. filter ( id = nid).delete() return redirect( '/students.html' ) def edit_students(request): if request.method = = "GET" : nid = request.GET.get( 'nid' , '') obj = models.Students.objects.get( id = nid) cs_list = models.Classes.objects. all () return render(request, 'edit_students.html' ,{ 'obj' :obj, 'cs_list' :cs_list}) elif request.method = = "POST" : nid = request.POST.get( 'nid' ,'') u = request.POST.get( 'username' , '') a = request.POST.get( 'age' , '') g = request.POST.get( 'gender' , '') c = request.POST.get( 'cs' , '') models.Students.objects. filter ( id = nid).update( username = u, age = a, gender = g, cs_id = c) return redirect( '/students.html' ) |
2.在urls.py 中配置url路由:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
from django.contrib import admin from django.urls import path from app01.views import classes,students,teachers urlpatterns = [ path( 'admin/' , admin.site.urls), path( 'classes.html' , classes.get_classes), path( 'add_classes.html' , classes.add_classes), path( 'del_classes.html' , classes.del_classes), path( 'edit_classes.html' , classes.edit_classes), path( 'students.html' , students.get_students), path( 'add_students.html' , students.add_students), path( 'del_students.html' , students.del_students), path( 'edit_students.html' , students.edit_students), # path('teachers.html', teachers.get_teachers), ] |
3.在template目录下建立所需的html页面文件:
get_students.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
<!DOCTYPE html> <html lang = "en" > <head> <style> tr td{ border: 1px solid #000;text-align:center;} < / style> <meta charset = "UTF-8" > <title>Title< / title> < / head> <body> <div> <table> <thead> <tr> <th> ID < / th> <th>姓名< / th> <th>年龄< / th> <th>性别< / th> <th>班级< / th> <th>操作< / th> < / tr> < / thead> <tbody> { % for row in stu_list % } <tr> <td>{{ row. id }}< / td> <td>{{ row.username }}< / td> <td>{{ row.age }}< / td> <td>{{ row.gender }}< / td> <td>{{ row.cs.title }}< / td> <td><a href = "/del_students.html?nid={{ row.id }}" rel = "external nofollow" rel = "external nofollow" >删除< / a> |<a href = "/edit_students.html?nid={{ row.id }}" rel = "external nofollow" rel = "external nofollow" >编辑< / a> < / td> < / tr> { % endfor % } < / tbody> < / table> < / div> <div><a href = "/add_students.html" rel = "external nofollow" rel = "external nofollow" >添加< / a> < / div> < / body> < / html> |
add_students
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
<!DOCTYPE html> < html lang = "en" > < head > < meta charset = "UTF-8" > < title >Title</ title > </ head > < body > < h1 >添加用户</ h1 > < form method = "post" action = "/add_students.html" > {% csrf_token %} < p >< input type = "text" name = "username" placeholder = "用户名" ></ p > < p >< input type = "text" name = "age" placeholder = "年龄" ></ p > < p > 男< input type = "radio" name = "gender" value = "1" > 女< input type = "radio" name = "gender" value = "0" > </ p > < p > < select name = "cs" > {% for row in cs_list %} < option value = "{{ row.id }}" >{{ row.title }}</ option > {% endfor %} </ select > </ p > < p >< input type = "submit" value = "提交" ></ p > </ form > </ body > </ html > |
edit_students.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
<!DOCTYPE html> < html lang = "en" > < head > < meta charset = "UTF-8" > < title >Title</ title > </ head > < body > < h1 >编辑用户</ h1 > < form method = "post" action = "/edit_students.html" > {% csrf_token %} < input type = "hidden" name = "nid" value = "{{ obj.id }}" > < p >< input type = "text" name = "username" placeholder = "用户名" ></ p > < p >< input type = "text" name = "age" placeholder = "年龄" ></ p > < p > 男< input type = "radio" name = "gender" value = "1" > 女< input type = "radio" name = "gender" value = "0" > </ p > < p > < select name = "cs" > {% for row in cs_list %} < option value = "{{ row.id }}" >{{ row.title }}</ option > {% endfor %} </ select > </ p > < p >< input type = "submit" value = "提交" ></ p > </ form > </ body > </ html > |
7.学员管理系统之给班级分配老师:
在teachers数据表中增加一些老师信息:
在pycharm右上角的Database打开面板,然后将template目录下边的db.splte3鼠标拖入到Database面板中,打开db==》app01_teachers表
点击“+”,然后填入老师信息,然后点击有“DB”标志的向上箭头,进行数据保存。
1.在classes.py中增加set_teachers函数
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
def set_teachers(request): if request.method = = 'GET' : nid = request.GET.get( 'nid' ,'') cls_obj = models.Classes.objects.get( id = nid) cls_teacher_list = cls_obj.a. all () all_teacher_list = models.Teachers.objects. all () return render(request, 'set_teachers.html' ,{ 'cls_teacher_list' :cls_teacher_list, 'all_teacher_list' :all_teacher_list, 'nid' :nid, }) elif request.method = = 'POST' : nid = request.POST.get( 'nid' , '') ids_str = request.POST.getlist( 'teacher_id' ,'') ids_int = [] for i in ids_str: i = int (i) ids_int.append(i) obj = models.Classes.objects.get( id = nid) obj.a. set (ids_int) return redirect( '/classes.html' ) |
2.在urls.py 中配置url路由:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
from django.contrib import admin from django.urls import path from app01.views import classes,students,teachers urlpatterns = [ path( 'admin/' , admin.site.urls), path( 'classes.html' , classes.get_classes), path( 'add_classes.html' , classes.add_classes), path( 'del_classes.html' , classes.del_classes), path( 'edit_classes.html' , classes.edit_classes), path( 'students.html' , students.get_students), path( 'add_students.html' , students.add_students), path( 'del_students.html' , students.del_students), path( 'edit_students.html' , students.edit_students), path( 'set_teachers.html' , classes.set_teachers), ] |
3.在template目录下建立所需的html页面文件:
set_teachers.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
<!DOCTYPE html> <html lang = "en" > <head> <meta charset = "UTF-8" > <title>Title< / title> < / head> <body> <form action = "/set_teachers.html" method = "post" > < input type = "hidden" name = "nid" value = "{{ nid }}" > { % csrf_token % } <select multiple size = "10" name = "teacher_id" > { % for item in all_teacher_list % } { % if item in cls_teacher_list % } <option value = "{{ item.id }}" selected = "selected" >{{ item.name }}< / option> { % else % } <option value = "{{ item.id }}" >{{ item.name }}< / option> { % endif % } { % endfor % } < / select> < input type = "submit" value = "提交" > < / form> < / body> < / html> |
对get_classes.html进行增添修改为:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
<!DOCTYPE html> <html lang = "en" > <head> <meta charset = "UTF-8" > <title>Title< / title> < / head> <body> <div> <table> <thead> <tr> <th> ID < / th> <th>名称< / th> <th>任课老师< / th> <th>操作< / th> < / tr> < / thead> <tbody> { % for row in cls_list % } <tr> <td>{{ row. id }}< / td> <td>{{ row.title }}< / td> <td> { % for item in row.a. all % } <span>{{ item.name }}< / span> { % endfor % } < / td> <td><a href = "/del_classes.html?nid={{ row.id }}" rel = "external nofollow" rel = "external nofollow" >删除< / a> |<a href = "/edit_classes.html?nid={{ row.id }}" rel = "external nofollow" rel = "external nofollow" >编辑< / a> |<a href = "/set_teachers.html?nid={{ row.id }}" rel = "external nofollow" >分配老师< / a> < / td> < / tr> { % endfor % } < / tbody> < / table> < / div> <div><a href = "/add_classes.html" rel = "external nofollow" rel = "external nofollow" >添加< / a> < / div> < / body> < / html> |
8.初识Ajax
Ajax是异步传输方式,偷偷的向后台发请求,不引起页面刷新,下面通过一个小例子来认识Ajax这种数据传输方式。
首先下载jQuery导入项目下的static目录下
1.在app01/Views目录下新建ajax.py
1
2
3
4
5
6
7
8
9
10
11
|
from django.shortcuts import render,redirect,HttpResponse def ajax1(request): return render(request, 'ajax1.html' ) def ajax2(request): u = request.GET.get( 'username' ) p = request.GET.get( 'password' ) return HttpResponse( '我愿意' ) |
2.在urls.py中配置相关路由
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
from django.contrib import admin from django.urls import path from app01.views import classes,students,teachers,ajax urlpatterns = [ path( 'admin/' , admin.site.urls), path( 'classes.html' , classes.get_classes), path( 'add_classes.html' , classes.add_classes), path( 'del_classes.html' , classes.del_classes), path( 'edit_classes.html' , classes.edit_classes), path( 'students.html' , students.get_students), path( 'add_students.html' , students.add_students), path( 'del_students.html' , students.del_students), path( 'edit_students.html' , students.edit_students), path( 'set_teachers.html' , classes.set_teachers), path( 'ajax1.html' , ajax.ajax1), path( 'ajax2.html' , ajax.ajax2), ] |
3.在template目录下新建ajax1.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
<!DOCTYPE html> <html lang = "en" > <head> <meta charset = "UTF-8" > <title>Title< / title> <style> .btn{ display: inline - block; padding: 5px 15px ; background - color: coral; color: white; cursor: pointer; } < / style> < / head> <body> <div> < input placeholder = "用户名" type = "text" > < input placeholder = "密码" type = "password" > <div class = "btn" >提交< / div> < / div> <script src = "/static/jquery-3.3.1.js" >< / script> <script> function submitForm() { var u = $( '#username' ).val(); var p = $( '#password' ).val(); $.ajax({ url: 'ajax2.html' , type : 'GET' , data:{username:u,password:p}, success:function (arg) { / / 回调函数 arg是服务器返回的字符串 console.log(arg) } }) } < / script> < / body> < / html> |
9.学员管理系统之Ajax删除学员: 1.在ajax.py中增加ajax4函数
1
2
3
4
5
6
7
8
9
|
from app01 import models def ajax4(request): nid = request.GET.get( 'nid' ) msg = '成功' try : models.Students.objects.get( id = nid).delete() except Exception as e: msg = str (e) return HttpResponse(msg) |
2.在urls.py中配置相关路由
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
from django.contrib import admin from django.urls import path from app01.views import classes,students,teachers,ajax urlpatterns = [ path( 'admin/' , admin.site.urls), path( 'classes.html' , classes.get_classes), path( 'add_classes.html' , classes.add_classes), path( 'del_classes.html' , classes.del_classes), path( 'edit_classes.html' , classes.edit_classes), path( 'students.html' , students.get_students), path( 'add_students.html' , students.add_students), path( 'del_students.html' , students.del_students), path( 'edit_students.html' , students.edit_students), path( 'set_teachers.html' , classes.set_teachers), path( 'ajax1.html' , ajax.ajax1), path( 'ajax2.html' , ajax.ajax2), path( 'ajax4.html' , ajax.ajax4), ] |
3.对get_students.html进行添加修改:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
<!DOCTYPE html> <html lang = "en" > <head> <meta charset = "UTF-8" > <title>Title< / title> < / head> <body> <div> <table> <thead> <tr> <th> ID < / th> <th>姓名< / th> <th>年龄< / th> <th>性别< / th> <th>班级< / th> <th>操作< / th> < / tr> < / thead> <tbody> { % for row in stu_list % } <tr nid = "{{ row.id }}" > <td>{{ row. id }}< / td> <td>{{ row.username }}< / td> <td>{{ row.age }}< / td> <td>{{ row.gender }}< / td> <td>{{ row.cs.title }}< / td> <td><a href = "/del_students.html?nid={{ row.id }}" rel = "external nofollow" rel = "external nofollow" >删除< / a> |<a href = "#" rel = "external nofollow" >Ajax删除< / a> |<a href = "/edit_students.html?nid={{ row.id }}" rel = "external nofollow" rel = "external nofollow" >编辑< / a> < / td> < / tr> { % endfor % } < / tbody> < / table> < / div> <div><a href = "/add_students.html" rel = "external nofollow" rel = "external nofollow" >添加< / a> < / div> < / body> <script src = "/static/jquery-3.3.1.js" >< / script> <script> function removeStudent(ths) { var nid = $(ths).parent().parent().attr( 'nid' ); $.ajax({ url: '/ajax4.html' , type : 'GET' , data:{nid:nid}, success:function (arg) { if (arg = = '成功' ){ window.location. reload (); } else { alert(arg); } } }) } < / script> < / html> |
原文链接:https://www.cnblogs.com/xuepangzi/p/8493853.html