一、bootstrap模板使用

1.去bootstrap官网找一个合适的模板,下载下来,右键另存为即可

bootstrap官网---->bootstrap中文文档3-------->起步-------->找到合适模板------>右键另存为

2.在项目目录下新建statics目录,在statics目录下新建4个子目录,分别是:css、js、image、plugin,将下载下来的js放到js目录,css放到css目录,图片放到image目录

3.settings.py也要指定静态文件目录

STATIC_URL = '/static/'

STATICFILES_DIRS = (
os.path.join(BASE_DIR,'statics'),
)

3.将下载下来的网页放在templates目录下,并改名为base.html,它基本上全是css和js,它将被用作公共模板,

再创建一个index.html,index放的是下载下来的网页去掉css和js的部分,主要是公共内容和框架,它将被用做app网页的模板

然后在templates目录下新建一个app的目录:app,app目录用来存放app自己的页面。

base.html

<!DOCTYPE html>
<html lang="zh-CN">
<head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<!-- 上述3个meta标签*必须*放在最前面,任何其他内容都*必须*跟随其后! -->
<meta name="description" content="">
<meta name="author" content="">
{# meta全部保留,IE浏览器相关的可要可不要,图标与css也要全部保留#}
<link rel="icon" href="http://v3.bootcss.com/favicon.ico">
<title>王腾的个人站点</title>
<link href="/static/css/bootstrap.min.css" rel="stylesheet">
<link href="/static/css/dashboard.css" rel="stylesheet">
{% block header-resources %} {% endblock %}
{# 这里留一个block块,可以方便其他网页继承时进行扩展 来添加自定义样式#}
</head> <body>
{% block body %} {% endblock %}
{# 这里留一个block body块,可以方便其他网页继承时进行扩展 在body里添加自定义的内容#}
<script src="/static/js/jquery.min.js"></script>
<script src="/static/js/bootstrap.min.js"></script>
<script src="/static/js/holder.min.js"></script>
{# 这些js全部保留,js的路径static是settings.py中STATIC_URL = '/static/'对应的STATIC_URL,而不是实际的目录名#}
<script>
{# 这里是自定义js,点击相应按钮时,按钮变颜色#}
$(document).ready(function () {
var current_url = "{{ request.path }}";
$('.nav-sidebar a[href="{{ request.path }}"]').parent().addClass('active');
})
</script>
</body></html>

index.html

{% extends 'base.html' %}
{#这里写继承base.html#}
{% block body %}
{# 这里在block body里自定义body的内容,要注意写上block body#}
{% block nav-bar %}
{# 这个block块是页面最上边的导航栏,为了其他页面可自定制导航栏,这里弄一个块,当其它页面写上 {% block nav-bar %}{% endblock %}时#}
{# 其它页面的导航栏位置就不会显示模板的导航栏了#}
<nav class="navbar navbar-inverse navbar-fixed-top">
<div class="container-fluid">
<div class="navbar-header">
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false" aria-controls="navbar">
<span class="sr-only">Toggle navigation</span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<a class="navbar-brand" href="http://v3.bootcss.com/examples/dashboard/#">TEST</a>
</div>
<div id="navbar" class="navbar-collapse collapse">
<ul class="nav navbar-nav navbar-right">
<li><a href="http://v3.bootcss.com/examples/dashboard/#">Dashboard</a></li>
<li><a href="http://v3.bootcss.com/examples/dashboard/#">Settings</a></li>
<li><a href="http://v3.bootcss.com/examples/dashboard/#">Profile</a></li>
<li class="dropdown">
{# 这里添加一个下拉菜单,也是找的模板上的#}
<a href="http://v3.bootcss.com/examples/dashboard/#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false">{{ request.user.userprofile.name }}<span class="caret"></span></a>
<ul class="dropdown-menu">
<li><a href="http://v3.bootcss.com/examples/dashboard/#">首页</a></li>
<li><a href="/logout">注销</a></li>
</ul>
</li>
</ul>
<form class="navbar-form navbar-right">
<input type="text" class="form-control" placeholder="Search...">
</form>
</div>
</div>
</nav>
{% endblock %}
<div class="container-fluid">
<div class="row">
{% block side-bar %}
{# 这里写一个左边栏block块,也是为了其他页面可以自定制#}
<div class="col-sm-3 col-md-2 sidebar">
<ul class="nav nav-sidebar">
{% block side-bar-menu %}
{% for role in request.user.userprofile.roles.all %}
<h3></h3>
{# <li class="active"><a href="http://v3.bootcss.com/examples/dashboard/#">{{ role }}<span class="sr-only">(current)</span></a></li>#}
{% for menu in role.menus.all %}
<li>
<a href="{% if menu.url_type == 0 %}{% url menu.url_name %}{% else %}{{ menu.url_name }}
{# 这里的{% url menu.url_name %}就是取得数据库中的url_name,并且将这个url_name与urls.py中的name做比较,相同才可以跳转到相应页面,#}
{% endif %}">{{ menu.name }}</a>
</li>
{% endfor %}
{% endfor %}
{% endblock %}
</ul>
</div>
{% endblock %}
{% block right-container %}
<div class="col-sm-9 col-sm-offset-3 col-md-10 col-md-offset-2 main">
{% block right-container-content %}
<h1 class="page-header">Dashboard</h1>
<div class="row placeholders">
<div class="col-xs-6 col-sm-3 placeholder">
<img src="" width="" height="" class="img-responsive" alt="Generic placeholder thumbnail">
<h4>Label</h4>
<span class="text-muted">Something else</span>
</div>
<div class="col-xs-6 col-sm-3 placeholder">
<img src="" width="" height="" class="img-responsive" alt="Generic placeholder thumbnail">
<h4>Label</h4>
<span class="text-muted">Something else</span>
</div>
<div class="col-xs-6 col-sm-3 placeholder">
<img src="" width="" height="" class="img-responsive" alt="Generic placeholder thumbnail">
<h4>Label</h4>
<span class="text-muted">Something else</span>
</div>
<div class="col-xs-6 col-sm-3 placeholder">
<img src="" width="" height="" class="img-responsive" alt="Generic placeholder thumbnail">
<h4>Label</h4>
<span class="text-muted">Something else</span>
</div>
</div>
<h2 class="sub-header">Section title</h2>
{% endblock %}
</div>
{% endblock %}
</div>
</div>
{% endblock %}

app/app.html

{% extends 'index.html' %}

{% block right-container-content %}
<h2 class="page-header">客户信息</h2>
{{ request.path }} {% endblock %}

二.django管理界面设置
1.项目/urls.py

from django.conf.urls import url,include
from django.contrib import admin
from new import views #导入app的views urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^crm/', include('crm.urls')),
url(r'^login/', views.acc_login), #登录函数
url(r'^logout/', views.acc_logout), #注销函数
]

2.app/urls.py

from django.conf.urls import url,include
from django.contrib import admin
from crm import views 导入app的views urlpatterns = [
url(r'^$', views.dashboard,name='sales'), # 设置该页面为首页
url(r'^customer$', views.customer,name='customer'), # 注意这里的name='customer'的字段customer要与数据库中的url_name 存的customer完全相同才行
]

3.项目/views.py(使用django自带的登录验证)

#!/usr/bin/python
# -*- coding:utf-8 -*-
# author:wt from django.shortcuts import render,redirect
from django.contrib.auth import authenticate,login,logout # 使用django自带的认证,登录,登出系统 def acc_login(request):
if request.method == 'POST':
username = request.POST.get('username')
password = request.POST.get('password')
user = authenticate(username=username,password=password)
print('res',user.userprofile.name)
if user:
# 认证成功
login(request,user) # 将用户名写到session里
return redirect('/crm')
return render(request,'login.html') def acc_logout(request):
logout(request) # 登出
return redirect('/login')

app/vies.py

from django.shortcuts import render
from django.contrib.auth.decorators import login_required # 添加用户验证,直接输入业务网址,会自动跳转到登录界面
# Create your views here.
@login_required # 添加用户验证,直接输入业务网址,会自动跳转到登录界面
def dashboard(request): return render(request,'crm/dashboard.html')
@login_required
def customer(request): return render(request,'crm/customer.html')

setting.py

STATIC_URL = '/static/'
STATICFILES_DIRS = (
os.path.join(BASE_DIR,'statics'),
) LOGIN_URL = '/login/' # 使用django自带的认证

4.app/models.py  创建app的表

from django.db import models
from django.contrib.auth.models import User # Create your models here.
class Customer(models.Model): # 客户表
name = models.CharField(max_length=32)
qq = models.CharField(max_length=64, unique=True)
weixin = models.CharField(max_length=64, blank=True, null=True)
phone = models.PositiveIntegerField(blank=True, null=True) # 只能存正数
age = models.PositiveSmallIntegerField(blank=True,null=True)
gender = models.PositiveIntegerField(choices=((0,'男'),(1,'女')))
source_choices = ((0, '百度商桥'),
(1,'51CTO'),
(2,'QQ群'),
(3,'知乎'),
(4,'SOGO'),
(5,'转介绍'),
)
source = models.SmallIntegerField(choices=source_choices) # 存0-65535的数字
referral_from = models.ForeignKey('self',related_name='my_referreals',
blank=True,null=True,verbose_name='转介绍') # 存转介绍的学生,关联自己表,‘related_name’用于反向查找
consult_courses = models.ManyToManyField('Course') # 咨询的课程
status_choices = ((0,'已报名'),
(1,'未报名'),
(2,'已退学'),
)
status = models.SmallIntegerField(choices=status_choices) # 报名状态
consulttant = models.ForeignKey('UserProfile',verbose_name='课程顾问') # 课程顾问
consult_content = models.TextField(max_length=1024) # 学生描述
date = models.DateTimeField(auto_now_add=True) #auto_now_add 创建记录时,自动添加创建时间,auto_now修改记录时,将创建时间改为修改时的时间 def __str__(self):
return '%s' % self.name # 注意这里都要返回字符串,不能直接返回self.name,会报错,也不能不返回东西,否则在管理界面会看到一堆object字母 class Emrollment(models.Model): # 学生报名表,只要有报名,就会创建一条学生与所报课程的记录
customer = models.ForeignKey('Customer')
class_grade = models.ForeignKey('ClassList')
enrollment_date = models.DateField() # 报名日期 def __str__(self):
return '%s' % self.customer class Meta:
unique_together = ('customer','class_grade') # 设置联合唯一 class FollowUpRecord(models.Model): # 跟进记录表
customer = models.ForeignKey('Customer')
content = models.TextField(max_length=1024)
status_choices = ((0, '绝无报名计划'),
(1, '一个月内报名'),
(2, '半个月内报名'),
(2, '已选择其他机构'),
)
status = models.SmallIntegerField(choices=status_choices) # 报名状态
consulttant = models.ForeignKey('UserProfile', verbose_name='课程顾问') # 课程顾问
date = models.DateTimeField(auto_now_add=True) #auto_now_add 创建记录时,自动添加创建时间,auto_now修改记录时,将创建时间改为修改时的时间
def __str__(self):
return "%s" % self.customer class Course(models.Model): # 课程表
name = models.CharField(unique=True,max_length=64)
price = models.PositiveIntegerField(default=19800)
outline = models.TextField() # 课程大纲 def __str__(self):
return '%s' % self.name class ClassList(models.Model): # 班级表
course = models.ForeignKey('Course')
semester = models.PositiveSmallIntegerField(verbose_name='学期')
class_type_choices = ((0,'脱产'),
(1,'周末'),
(2,'网络'),
)
branch = models.ForeignKey('Branch')
class_type = models.PositiveSmallIntegerField(choices=class_type_choices)
teachers = models.ManyToManyField('UserProfile')
start_date = models.DateField()
end_date = models.DateField() def __str__(self):
return '%s' % self.course class CourseRecord(models.Model): # 每节课上课记录与考勤
class_grade = models.ForeignKey('ClassList')
day_number = models.PositiveSmallIntegerField(verbose_name='节次')
teacher = models.ForeignKey('UserProfile')
course_content = models.TextField(verbose_name='课程内容',max_length=1024)
homework = models.BooleanField(default=True)
homework_title = models.CharField(max_length=128,blank=True,null=True)
homework_requirment = models.TextField(verbose_name='作业需求',max_length=1024,blank=True,null=True) def __str__(self):
return '%s daynum:%s' % (self.class_grade,self.day_number) class Meta:
unique_together = ('class_grade','day_number') class StudyRecord(models.Model): # 每个学生的每节课的成绩记录
course_record = models.ForeignKey('CourseRecord')
student = models.ForeignKey('Emrollment')
score_choices = ((100,'A+'),
(90,'A'),
(85,'B+'),
(80,'B'),
(75,'B-'),
(70,'C+'),
(65,'C'),
(40,'C-'),
(-20,'D'),
(-50,'COPY'),
(0,'N/A'),
)
score = models.SmallIntegerField(choices=score_choices)
show_status_choices = ((0,'缺勤'),
(1,'迟到'),
(2,'已签到'),
)
show_status = models.SmallIntegerField(choices=score_choices)
grade_comment = models.TextField(max_length=1024,blank=True,null=True) def __str__(self):
return "%s student:%s" % (self.course_record,self.student) class Meta:
unique_together = ('course_record','student') class UserProfile(models.Model): # 用户表
user = models.OneToOneField(User)
name = models.CharField(max_length=32)
roles = models.ManyToManyField('Role',blank=True,null=True) def __str__(self):
return '%s' % self.name class Role(models.Model): # 角色管理
name = models.CharField(max_length=32,unique=True)
menus = models.ManyToManyField('Menu') def __str__(self):
return '%s' % self.name class Branch(models.Model): # 分校管理
name = models.CharField(max_length=128,unique=True) def __str__(self):
return '%s' % self.name class Menu(models.Model): # 动态菜单
name = models.CharField(max_length=32,unique=True)
url_type = models.SmallIntegerField(choices=((0,'relative_url'),(1,'absolut_url')))
url_name = models.CharField(unique=True,max_length=128) # 存储每个学生或员工的url def __str__(self):
return '%s' % self.name

5.app/admin.py    使用django管理界面(进行app表注册)

from django.contrib import admin
from crm import models
# Register your models here.
class CustomerAdmin(admin.ModelAdmin):
list_display = ('id','name','qq','consulttant','source','consult_content','status','date') # 在管理界面根据这些列明显示详细信息
list_filter = ('source','status','consulttant') # 在管理界面显示过滤条件
search_fields = ('qq','name') # 在管理界面增加搜索框,搜索条件是qq或name
list_editable = ('status',) # 在管理界面增加status字段的编辑框 admin.site.register(models.Customer,CustomerAdmin)
admin.site.register(models.FollowUpRecord)
admin.site.register(models.Emrollment)
admin.site.register(models.Course)
admin.site.register(models.ClassList)
admin.site.register(models.StudyRecord)
admin.site.register(models.UserProfile)
admin.site.register(models.Branch)
admin.site.register(models.Role)
admin.site.register(models.Menu)
admin.site.register(models.CourseRecord)

django管理界面使用与bootstrap模板使用的更多相关文章

  1. python Django 学习笔记(五)—— Django admin自动管理界面

    1,激活管理界面 修改settings.py MIDDLEWARE_CLASSES = ( 'django.middleware.common.CommonMiddleware', 'django.c ...

  2. django学习-管理界面、视图

    django管理界面 设计背景 为你的员工或客户生成一个用户添加,修改和删除内容的后台是一项缺乏创造性和乏味的工作.因此,django全自动地根据模型创建后台界面. django产生于一个公众页面和内 ...

  3. 【解决方案】Django管理页面无法显示静态文件

    [问题描述]:Django管理界面无法获取页面的css样式文件.图片等静态文件.调试模式下看到静态url显示404. [问题原因]:跟踪源码可以发现,静态文件的url是由Django自带的app(dj ...

  4. [Django]用户权限学习系列之权限管理界面实现

    本系列前三章: http://www.cnblogs.com/CQ-LQJ/p/5604331.htmlPermission权限基本操作指令 http://www.cnblogs.com/CQ-LQJ ...

  5. Django后台管理界面

    之前的几篇记录了模板视图.模型等页面展示的相关内容,这篇主要写一下后台admin管理界面的内容. 激活管理界面 Django管理站点完全是可选择的,之前我们是把这些功能给屏蔽掉了.记得上篇中Djang ...

  6. 【django小练习之主机管理界面】

    需求: 利用django,js,bootstrap等实现登录,主机管理等操作. 实现截图 登录界面 主机界面,添加及编辑 部门管理界面 代码实现 目录层级 settings.py "&quo ...

  7. django搭建一个小型的服务器运维网站-拿来即用的bootstrap模板

    目录 项目介绍和源码: 拿来即用的bootstrap模板: 服务器SSH服务配置与python中paramiko的使用: 用户登陆与session; 最简单的实践之修改服务器时间: 查看和修改服务器配 ...

  8. Django笔记 —— Admin(Django站点管理界面)

    最近在学习Django,打算玩玩网页后台方面的东西,因为一直很好奇但却没怎么接触过.Django对我来说是一个全新的内容,思路想来也是全新的,或许并不能写得很明白,所以大家就凑合着看吧- 本篇笔记(其 ...

  9. 基于bootstrap的漂亮网站后台管理界面框架汇总

    基于bootstrap的漂亮网站后台管理界面框架汇总 10个最新的 Bootstrap 3 管理模板 这里分享的 10 个模板是从最新的 Bootstrap 3 管理模板集合中挑选出来的,可以帮助你用 ...

随机推荐

  1. 数据库抽象层 pdo

    一 . PDO的连接 $host = "localhost"; $dbname = "hejuntest"; $username = "root&qu ...

  2. JSON Path表达式

      JSON Path 描述 $ 表示根元素 @ 表示当前节点 .  表示子节点 .. 选择所有符合条件的节点 * 所有节点 [] 迭代器标识,如数组下标 [,] 支持迭代器中多选 [start:en ...

  3. virtueBox实现虚拟机的复制和粘贴

    1.在设备--共享粘贴板--勾选双向. 2.在设备--拖放--勾选双向. 3.在设备--安装增强功能,然后进入虚拟机安装增强功能即可.

  4. { "result": null, "log_id": 304592860300941982, "error_msg": "image check fail", "cached": 0, "error_code": 222203, "timestamp": 1556030094 }

    这个是人脸识别时无法检测到图片报的错,有时候我们检测一张图片是否在库里面,当一张图片明显在里面,还检测不到,如下面是我的代码 package Test1; import java.io.IOExcep ...

  5. win7系统电脑显示windows副本不是正版怎么办

    win7系统电脑显示windows副本,可以:在开始输入框中输入cmd——以管理员权限运行——在命令行中输入SLMGR -REARM,——重启.

  6. 【转】asp.net中设置弹出谈话框的几种方式详解

    源地址:https://blog.csdn.net/zou15093087438/article/details/79637114 注:可用winform的MessageBox的方法,只需引用Syst ...

  7. HTML5新增的表单元素有哪些?

    表单控:color ,  calendar  ,  date ,  datetime, datetime-local,  time, mouth , week, email, url , search ...

  8. Spring核心--IOC&AOP

    Ioc(控制反转) 所谓的控制反转就是应用本身不负责依赖对象的创建及维护,依赖对象的创建及维护是由外部容器负责的.这样控制权就由应用转移到了外部容器,控制权的转移就是所谓反转. AOP(面向切面编程) ...

  9. [Error] ISO C++ forbids comparison between pointer and integer

    错误代码: if(a[i]=="G"&&b[i]!="C") return false; 改正后的代码: if(a[i]=='G'&&a ...

  10. python之读取文件的测试数据

    假设我们有一个叫testdata.txt的文件,现在在这个文件里面有测试数据,我们怎么利用前2小章学习的知识,读取测试数据呢? 测试数据如下: url:https://www.cnblogs.com/ ...