在上一篇,我们已经把我们做的运维外面套上了bootstrap框架,但是那仅仅是一个外壳,这一次是要把里面的壤也扣上这样的框架。
首先,编辑index.html,添加block元素,用于主页存放不同的内容:
{% block page_title %} {% endblock %} { { sub_title }}
{% block container %} {% endblock %}
之前在models.py里我们设定了很多个项目,比如alionlineECS,alifuncECS等等,那么对应每一个项目都会有一个html,在这里我命名:alionlineECS_list.html用于存放“阿里云线上环境服务器”信息,alifuncECS_list.html用于“阿里云测试环境服务器”信息,ksonlineECS_list.html用于存放“金山云线上环境服务器”信息,ksfuncECS_list.html用于“金山云测试环境服务器”信息,同时修改index.html中Table下的链接,将其中的链接指向上面那些html们:
建立res_list.html放在之前的template文件夹里,用来存放资源类表格,并把它作为一个模板,供其他页面继承,这样可以节省大量的重复代码。
{% extends "index.html" %} {% block page_css %} {% endblock %} {% block page_title %} 基础资料 {% endblock %} {% block container %} {% load staticfiles %}
alionlineECS_list.html,alifuncECS_list.html,slb_list.html等html文件继承res_list.html,并将各自不一样的内容在相应的block中进行填充,比如alionlineECS_list.html就是下面的样子:
{% extends "res_list.html" %}{% block search %}{% endblock %}{% block table_tr %}云服务器名称云服务器类型云服务器内网地址云服务器外网地址云服务器外网带宽云服务器配置备注登记人{% endblock %}{% block table_td %}{ { item.ecs_name }}{ { item.ecs_type }}{ { item.ecs_inip }}{ { item.ecs_outip }}{ { item.ecs_ipwidth }}{ { item.ecs_spec }}{ { item.ecs_remarks }}{ { item.ecs_signer }}{% endblock %}
而slb_list.html就是这样:
{% extends "res_list.html" %}{% block search %}{% endblock %}{% block table_tr %}负载均衡名称网络类型转发规则ip地址负载均衡协议前端端口后端端口负载均衡协议前端端口后端端口登记人备注{% endblock %}{% block table_td %}{ { item.slb_name }}{ { item.slb_type }}{ { item.slb_algorithm }}{ { item.slb_ip }}{ { item.slb_protocol }}{ { item.slb_fport }}{ { item.slb_bport }}{ { item.slb_protocol2 }}{ { item.slb_fport2 }}{ { item.slb_bport2 }}{ { item.slb_signer }}{ { item.slb_remarks }}{% endblock %}
rds_list.html的代码如下:
{% extends "res_list.html" %}{% block search %}{% endblock %}{% block table_tr %}数据库名称数据库类型mysql版本数据库规格备注数据库地址存储空间登记人{% endblock %}{% block table_td %}{ { item.rds_name }}{ { item.rds_type }}{ { item.rds_mysql }}{ { item.rds_spec }}{ { item.rds_remark }}{ { item.rds_ip }}{ { item.rds_status }}{ { item.rds_signer }}{% endblock %}
网页代码都准备好了,再往下的内容是修改views.py,把lists那个函数改成这样:
def lists(request,table): #不同的需求跳到不同的界面 if table == 'alionlineECS': data = alionlineECS.objects.all() list_template = 'alionlineECS_list.html' sub_title = '阿里云线上环境服务器' if table == 'alifuncECS': data = alifuncECS.objects.all() list_template = 'alifuncECS_list.html' sub_title = '阿里云测试环境服务器' if table == 'ksonlineECS': data = ksonlineECS.objects.all() list_template = 'ksonlineECS_list.html' sub_title = '金山云线上环境服务器' if table == 'ksfuncECS': data = ksfuncECS.objects.all() list_template = 'ksfuncECS_list.html' sub_title = '金山云线上环境服务器' if table == 'SLB': data = SLB.objects.all() list_template = 'slb_list.html' sub_title = '负载均衡' if table == 'RDS': data = RDS.objects.all() list_template = 'rds_list.html' sub_title = '数据库' #建立一个context,将值传递到对应的页面 context = { 'data': data, 'table': table, 'sub_title': sub_title, } #跳转到相应页面,并将具体的值传递过去 return render(request,list_template,context)
add的函数应该是这样:
def add(request,table): #根据提交的请求不同,获取来自不同Form的表单数据 if table == 'alionlineECS': form = alionlineForm(request.POST or None) if table == 'alifuncECS': form = alifuncForm(request.POST or None) if table == 'ksonlineECS': form = ksonlineForm(request.POST or None) if table == 'ksfuncECS': form = ksfuncForm(request.POST or None) if table == 'SLB': form = SLBForm(request.POST or None) if table == 'RDS': form = RDSForm(request.POST or None) #判断form是否有效 if form.is_valid(): #创建实例,需要做些数据处理,暂不做保存 instance = form.save(commit=False) #将登录用户作为登记人 if table == 'alionlineECS': instance.ecs_signer = request.user if table == 'alifuncECS': instance.ecs_signer = request.user if table == 'ksonlineECS': instance.ecs_signer = request.user if table == 'ksfuncECS': instance.ecs_signer = request.user if table == 'SLB': instance.slb_signer = request.user if table == 'RDS': instance.rds_signer = request.user #保存该实例 instance.save() #跳转至列表页面 return redirect('lists',table=table) #创建context来集中处理需要传递到页面的数据 context = { 'form': form, 'table': table, } #如果没有有效提交,则仍留在原来页面 return render(request,'add.html',context)
同时,我们要添加两个新的函数,一个叫edit,他的内容如下:
#修改数据,函数中的pk代表数据的iddef edit(request,table,pk): if table == 'alionlineECS': #这是Django的一个快捷方法,通过pk去line表中取值,如果有值则返回,如果无值则抛出http404的异常 #具体信息可参考https://docs.djangoproject.com/en/1.9/topics/http/shortcuts/ table_ins = get_object_or_404(alionlineECS,pk=pk) #通过instance来将Form的数据做填充 form = alionlineForm(request.POST or None,instance=table_ins) sub_title = '修改阿里云线上环境信息' if table == 'alifuncECS': table_ins = get_object_or_404(alifuncECS,pk=pk) form = alifuncForm(request.POST or None,instance=table_ins) sub_title = '修改阿里云线上环境信息' if table == 'ksonlineECS': table_ins = get_object_or_404(ksonlineECS,pk=pk) form = ksonlineForm(request.POST or None,instance=table_ins) sub_title = '修改金山云线上环境服务器信息' if table == 'ksfuncECS': table_ins = get_object_or_404(ksfuncECS,pk=pk) form = ksfuncForm(request.POST or None,instance=table_ins) sub_title = '修改金山云测试环境服务器信息' if table == 'SLB': table_ins = get_object_or_404(SLB,pk=pk) form = SLBForm(request.POST or None,instance=table_ins) sub_title = '修改负载均衡信息' if table == 'RDS': table_ins = get_object_or_404(RDS,pk=pk) form = RDSForm(request.POST or None,instance=table_ins) sub_title = '修改数据库信息' #判断form是否有效 if form.is_valid(): #创建实例,需要做些数据处理,暂不做保存 instance = form.save(commit=False) #将登录用户作为登记人,在修改时,一定要使用str强制 if table == 'alionlineECS': instance.ecs_signer = str(request.user) if table == 'alifuncECS': instance.ecs_signer = str(request.user) if table == 'ksonlineECS': instance.ecs_signer = str(request.user) if table == 'ksfuncECS': instance.ecs_signer = str(request.user) if table == 'SLB': instance.slb_signer = str(request.user) if table == 'RDS': instance.rds_signer = str(request.user) #保存该实例 instance.save() #跳转至列表页面,配合table参数,进行URL的反向解析 return redirect('lists', table=table) context = { 'table': table, 'form': form, 'page_title': '基础资料', 'sub_title': sub_title, } #与res_add.html用同一个页面,只是edit会在res_add页面做数据填充 return render(request,'res_add.html',context)
另一个函数是delete,这个是用来删除的,内容如下:
#删除操作def delete(request,table,pk): #选择相应的表格 if table == 'alionlineECS': #通过id值获取相应表格的实例,有值则返回,无值则抛出异常 table_ins = get_object_or_404(alionlineECS,pk=pk) if table == 'alifuncECS': table_ins = get_object_or_404(alifuncECS,pk=pk) if table == 'ksonlineECS': table_ins = get_object_or_404(ksonlineECS,pk=pk) if table == 'ksfuncECS': table_ins = get_object_or_404(ksfuncECS,pk=pk) if table == 'SLB': table_ins = get_object_or_404(SLB,pk=pk) if table == 'RDS': table_ins = get_object_or_404(RDS,pk=pk) #接收通过AJAX提交过来的POST if request.method == 'POST': #删除该条目 try: table_ins.delete() #删除成功,则data信息为success data = 'success' except IntegrityError: #如因外键问题,或其他问题,删除失败,则报error data = 'error' #将最后的data值传递至JS页面,进行后续处理,safe是将对象序列化,否则会报TypeError错误 return JsonResponse(data,safe=False)
别忘了这里还要修改一下主urls.py,添加edit和delete:
from django.conf.urls import url,includefrom django.contrib import adminimport Online.viewsadmin.autodiscover()from Online import views as Online_viewsurlpatterns = [ url(r'^admin/',admin.site.urls), url(r'^lists/(?P
启动django,在浏览器里输入"外网地址:8000/lists/slb"就发现原来那个白色的界面已经运用了boostrap模板,如下:
而打开"外网地址:8000/lists/alionlineECS",对应阿里区线上环境的资料也是套用了boostrap模板:
当你点击“添加数据”的时候,界面也是会正确转向的:
但是这个增加的页面很难看,白白的底儿,很挫,我们也希望这个增加的界面也有模板的样子。于是这里要用一个django-crispy-forms的app,首先在服务器里,使用#pip install --upgrade django-crispy-forms下载并安装。
然后在settings.py中加入相关app,并使其使用bootstrap3的前端。修改settings.py如下:
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'Online', 'SLB', 'RDS', #crispy app 把这个APP添加进去 'crispy_forms',]
然后还要在settings.py后面追加下面一句话:
#App settings CRISPY_TEMPLATE_PACK = 'bootstrap3'
再修改add.html文件,把crispy.form应用进去:
{% load crispy_forms_tags %}
然后再返回来看看添加的界面,嗯,好像变样了:
我们现在为了统一,把add.html改成res_add.html,同时继承index.html,将res_add.html中的内容填充到index的Container block。
{% extends "index.html" %} {% load crispy_forms_tags %}{% block page_title %} 基础资料{% endblock %}{% block container %}
然后再把views.py里面add函数里面最后那一行
return render(request,'add.html',context)
改成
return render(request,'res_add.html',context)
至此,整个添加界面就全部继承过来了: