day18-基于ORM实现用户增加、删除、修改以及查看详细

一、前言

  今天我们来实现用户的增加,删除,以及修改的功能,这个是我日常创建模板中经常遇到的,今天我们来看看这个怎么实现的。这篇博客是基于上一篇博客编写的  day18-基于ORM实现用户登录 

二、实现用户增加

说明:我们来编写一下增加一个用户

urls.py的代码如下,因为我们在user_info的路径下添加的,所以我们暂时先用这个url。

from django.urls import re_path,path
from app01 import views

urlpatterns = [
    path('user_info/',views.user_info),
]

view.py代码:

def user_info(request):
    #查看
    if request.method == "GET":
        user_list = models.UserInfo.objects.all()
        return  render(request,'user_info.html',{'user_list':user_list})
    #添加
    elif request.method == "POST":
        u = request.POST.get('user')
        p = request.POST.get('pwd')
        models.UserInfo.objects.create(username=u,password=p)
        return redirect("/cmdb/user_info/")

templates模板的user_info.html代码如下:

<body>
    <div style="height: 48px;background: #eeeeee;color: rebeccapurple;">
        鸿哥哥凌晨三点玩愤怒的小鸟
    </div>
    <div>
        <div style="position: absolute;top: 48px;bottom: 0;left: 0;width: 200px;background: beige;">
            <a class="menu" href="/cmdb/user_info">用户管理</a>
            <a class="menu" href="/cmdb/user_group">用户组管理</a>
        </div>
        <div style="position: absolute;top: 48px;left: 210px;bottom: 0;right: 0;overflow: auto;">
            <h3>添加用户</h3>
            <form method="post" action="/cmdb/user_info/">
                <input type="text" name="user"/>
                <input type="text" name="pwd"/>
                <input type="submit" value="添加"/>
            </form>
            <h3>用户列表</h3>
            <ul>
                {% for row in user_list %}
                    <li><a href="/cmdb/userdetail-{{ row.id }}/">{{ row.username }}</a>|
                        <a href="/cmdb/userdel-{{ row.id }}">删除</a> |
                        <a href="/cmdb/useredit-{{ row.id }}">编辑</a> |
                    </li>
                {% endfor %}
            </ul>
        </div>
    </div>
</body>

如图:

三、删除

说明:点击上面删除的按钮,则删除当前记录

url.py的代码如下:根据id,删除此用户

from django.urls import re_path,path
from app01 import views

urlpatterns = [
    re_path('^userdel-(?P<nid>\d+)/',views.user_del),
]

view.py的代码:

def user_del(request,nid):
    models.UserInfo.objects.filter(id=nid).delete()
    return redirect("/cmdb/user_info/")

如图:

四、修改

说明:我对某条记录进行编辑

urls.py的代码如下:

from django.urls import re_path,path
from app01 import views

urlpatterns = [
    re_path('^useredit-(?P<nid>\d+)/',views.user_edit),
]

view.py的代码如下:

def user_edit(request,nid):
    if request.method == "GET":
        obj = models.UserInfo.objects.filter(id=nid).first()
        return render(request,'user_edit.html',{"obj":obj})
    elif request.method == "POST":
        nid = request.POST.get("id")
        u = request.POST.get("username")
        p = request.POST.get("password")
        models.UserInfo.objects.filter(id=nid).update(username=u,password=p)
        return redirect('/cmdb/user_info/')

templates的模板user_edit.html代码如下:

<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        body{
            margin: 0 auto;
        }
        .menu{
            display: block;
            padding: 5px;
        }
    </style>
</head>
<body>
    <div style="height: 48px;background: #eeeeee;color: rebeccapurple;">
        鸿哥哥凌晨三点玩愤怒的小鸟
    </div>
    <div>
        <div style="position: absolute;top: 48px;bottom: 0;left: 0;width: 200px;background: beige;">
            <a class="menu" href="/cmdb/user_info">用户管理</a>
            <a class="menu" href="/cmdb/user_group">用户组管理</a>
        </div>
        <div style="position: absolute;top: 48px;left: 210px;bottom: 0;right: 0;overflow: auto;">
            <h1>编辑用户</h1>
            <form method="post" action="/cmdb/useredit-{{ obj.id }}/">
                <input style="display: none;" type="text" name="id" value="{{ obj.id }}">
                <input type="text" name="username" value="{{ obj.username }}">
                <input type="text" name="password" value="{{ obj.password }}">
                <input type="submit" value="提交">
            </form>
        </div>
    </div>
</body>

如图:

 

posted @ 2018-03-10 13:22  帅丶高高  阅读(221)  评论(0)    收藏  举报