• 博客系统-后台管理首页


    url配置

     url(r'^(?P<username>.*)/backindex/$',views.backIndex),

    视图配置:

    # 后台管理首页
    def backIndex(request,username):
        if not request.user.is_authenticated():     #没有通过验证,直接跳转到收益也
            return redirect("/login/")
    
        article_obj = models.Article.objects.filter(user__username=username)
        paginator = Paginator(article_obj, 4)
        page_range = paginator.page_range
        num = request.GET.get("page", 1)
        article_obj = paginator.page(num)
        return render(request, "backendindex.html",locals())

    前端相关

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>{{ request.user.username }}的后台管理首页</title>
        <link rel="stylesheet" href="/static/bootstrap-3.3.7/css/bootstrap.min.css">
        <link rel="stylesheet" href="/static/blog/manmager_page.css">
        <script src="/static/jquery/jquery-3.2.1.min.js"></script>
        <script src="/static/jquery/jquery.cookie.js"></script>
    
        <script src="/static/kindeditor/kindeditor-all.js"></script>
        <script src="/static/kindeditor/lang/zh-CN.js"></script>
    
    
    </head>
    <body>
    
    <div class="headding">
        <div class="container"><h2>welcome<a href=""> {{ request.user.username }}</a> to myhome_page </h2></div>
    </div>
    <hr>
    
    <div class="container">
        <div class="row">
    
    
            <div class="col-md-3">
    
                <div class="panel panel-primary">
                    <div class="panel-heading"><h2>后台管理页面</h2></div>
                    <div class="panel-body">
                        <h3><a href="/blog/{{ request.user.username }}/backindex/">后台管理首页</a></h3>
                        <h3><a href="/blog/{{ request.user.username }}">个人博客主页</a></h3>
                        <h3><a href="/blog/{{ request.user.username }}/backindex/">文章管理</a></h3>
                        <h3><a href="/blog/{{ request.user.username }}/backindex/tags/">标签管理</a></h3>
                        <h3><a href="/blog/{{ request.user.username }}/backindex/category/">分类管理</a></h3>
                    </div>
                </div>
            </div>
    
    
            <div class="col-md-8">
                {% block manageCon %}
                    <div class="panel panel-default">
                        <div class="panel-heading">用户文章信息</div>
                        <div class="panel-body">
                            <a href="/blog/{{ request.user.username }}/backindex/addarticle/">
                        <button class="btn btn-primary">+添加文章</button>
                    </a>
                            <table class="table table-bordered table-hover">
                        <tr>
                            <th>编号</th>
                            <th>标题</th>
                            <th>评论数</th>
                            <th>点赞数</th>
                            <th>创建时间</th>
                            <th>编辑</th>
                            <th>删除</th>
                        </tr>
                        {% for article in article_obj %}
                            <tr>
                                <td>{{ forloop.counter }}</td>
                                <td>{{ article.title }}</td>
                                <td>{{ article.comment_count }}</td>
                                <td>{{ article.up_count }}</td>
                                <td>{{ article.create_time }}</td>
                                <td>
                                    <a href="/blog/{{ request.user.username }}/backindex/addarticle/"><button class="btn edit btn-info " article_nid="{{ article.nid }}"><span
                                            class="glyphicon glyphicon-pencil">编辑</span></button></a>
                                </td>
                                <td>
                                    <button class="btn del btn-danger" article_nid="{{ article.nid }}"><span
                                            class="glyphicon glyphicon-remove">删除</span></button>
                                </td>
                            </tr>
                        {% endfor %}
    
                    </table>
                        </div>
                    </div>
    
    
                    <div class="page_page" style="text-align: center">
    
                        {#        分页按钮功能#}
                        {% block page %}
    
                            <nav aria-label="Page navigation">
                                <ul class="pagination">
                                    {% if article_obj.has_previous %}
                                        <li>
                                            <a href="/blog/{{ current_user.username }}/backindex/?page={{ article_list.previous_page_number }}"
                                               aria-label="Previous">上一页</a>
                                        </li>
                                    {% else %}
                                        <li class="disabled"><a href="" aria-label="Previous">上一页</a></li>
                                    {% endif %}
    
    
                                    {% for index in page_range %}
                                        {% if num == index %}
                                            <li class="active"><a
                                                    href="/blog/{{ request.user.username }}/backindex/?page={{ index }}">{{ index }}</a>
                                            </li>
                                        {% else %}
                                            <li>
                                                <a href="/blog/{{ request.user.username }}/backindex/?page={{ index }}">{{ index }}</a>
                                            </li>
                                        {% endif %}
                                    {% endfor %}
    
    
                                    {% if article_obj.has_next %}
                                        <li>
                                            <a href="/blog/{{ request.user.username }}/backindex/?page={{ article_list.next_page_number }}"
                                               aria-label="Previous">下一页</a></li>
                                    {% else %}
                                        <li class="disabled"><a href="" aria-label="Previous">下一页</a></li>
                                    {% endif %}
    
                                </ul>
                            </nav>
    
                        {% endblock %}
                    </div>
    
                {% endblock %}
    
            </div>
    
    
        </div>
    </div>
    
    
    {% block script %}
    
    {% endblock %}
    
    <script>
        $(".table").on("click", ".del", function () {
            $.ajax({
                url: "/blog/{{ request.user.username }}/backindex/delarticle/",
                type: "POST",
                headers: {"X-CSRFToken": $.cookie('csrftoken')},
                data: {
                    article_nid: $(this).attr("article_nid")
                },
                success: function (data) {
                    var data = JSON.parse(data)
                    if (data["is_del"]) {
                        location.href = "/blog/{{ request.user.username }}/backindex/"
                    }
                }
            })
        });
    
    
    </script>
    
    
    </body>
    </html>
    # 相关样式操作
    .title{ color: #2aabd2; } .article_region .article_con{ margin-left: 20px; } .updown .diggit{ 46px; height: 52px; background: url("/static/img/upup.gif") no-repeat; text-align: center; cursor: pointer; margin-top: 2px; padding-top: 5px; } .updown .buryit{ margin-left:20px; 46px; height: 52px; background: url("/static/img/downdown.gif") no-repeat; text-align: center; cursor: pointer; margin-top: 2px; padding-top: 5px; } /*.updown{*/ /*margin-left: 0;*/ /*}*/ .subComment_region #tbCommentAuthor{ background-position: 3px -3px; background-image: url("/static/img/icon_form.gif"); background-repeat: no-repeat; border: 1px solid #ccc; padding: 4px 4px 4px 30px; 300px; font-size: 13px; } #commentform_title { background-image: url("/static/img/icon_addcomment.gif"); background-repeat: no-repeat; padding: 0 0 0 25px; margin-bottom: 10px; } .author_avatar{ margin-left: 20px; } .had_comment_region input.author{ background-image: url("/static/img/icon_form.gif"); background-repeat: no-repeat; border: 1px solid #ccc; padding: 4px 4px 4px 30px; 300px; font-size: 13px; } #author_profile { float: left; 280px; margin-top: 0; margin-bottom: 10px; color: #000; margin-left: 0; font-size: 12px; } .author_profile_info { float: left; line-height: 18px; } div { display: block; } .author_avatar { vertical-align: top; float: left; margin-right: 5px; padding-top: 5px; padding-left: 2px; border: 0; } .author_profile_info { float: left; line-height: 18px; } .author_profile .author_profile_info .author_profile_detail a{ border-bottom: 2px dotted #333; color: #000; text-decoration: none; } .sendMsg2This:link, .sendMsg2This:visited, .sendMsg2This:active { font-size: 12px; text-decoration: none; background: url("/static/img/icoMsg.gif") no-repeat top left; padding-left: 20px; } .feedbackListSubtitle a:hover { color: #f60; text-decoration: none; } .sendMsg2This:hover { background: url("/static/img/icoMsg.gif") no-repeat bottom left; } .sp:hover{ color: #f60; text-decoration: none; } .sp { color: #666; font-weight: normal; } .pl{ margin-left: 0; } .comment{ margin-left: 20px; }
  • 相关阅读:
    互联网创业瞄准Web3.0时代 风投商造梦与毁梦 沧海
    SOA基础结构探究:服务调节与指挥 沧海
    排序算法小结 沧海
    上班触感 沧海
    经典程序摘录 沧海
    经典C程序100例 沧海
    ITIL进入快速增长期 2010年亚太市场将达$8亿 沧海
    必须要掌握的七种谈话技巧 沧海
    如何准备软件工程师的面试 沧海
    Junit教程 拂晓风起
  • 原文地址:https://www.cnblogs.com/52-qq/p/8669523.html
Copyright © 2020-2023  润新知