django 板块动态切换
需求:在同一页面的不同板块上可以实现动态切换,使用一个view实现,具体如下图所示,点击phy显示物理机列表,点击vm显示虚机列表,phy、vm对应的url均是动态生成:
实现思路:
1.新建两个表,servers表用于存放服务器种类,pvserver物理机虚机具体服务器信息。物理机和虚机不要分别存放于两个表中,这样的话在view中无法直接通过服务器类型得出相应的服务器列表
#存放服务器类型 class servers(models.Model): serverid = models.IntegerField(primary_key=True,unique=True) servertype = models.CharField(max_length=20) def __str__(self): return self.servertype #存储物理机和虚机服务器列表 class pvserver(models.Model): servertype = models.ForeignKey(servers,to_field='serverid',db_column='servertype') #设置外键,关联到servers表的serverid,保证服务器类型的一致 name = models.CharField(max_length=100) def __str__(self): return self.name
2.两个表同步到DB后,将其注册到admin后台,用于添加服务器信息
from .models import hv,vm,servers,physerver,vmserver,pvserver class serversAdmin(admin.ModelAdmin): #fields = ['sn', 'ip'] fieldsets = [ (None, {'fields': ['serverid']}), (None, {'fields': ['servertype']}), ] list_display = ('serverid', 'servertype') #add more columns. admin.site.register(servers,serversAdmin) class pvserverAdmin(admin.ModelAdmin): #fields = ['sn', 'ip'] fieldsets = [ (None, {'fields': ['servertype']}), (None, {'fields': ['name']}), ] list_display = ('servertype', 'name') #add more columns. admin.site.register(pvserver,pvserverAdmin)
3.新建view:
方法一(简单),直接查询pvserver表:
def servers(request,serverid): #serverid从下面的types中遍历出来,为了省事,才在该视图下使用types,其实types应该从另一个页面下使用 types = serversm.objects.all() #得出所有的服务器种类,在前端web展示 serverall = pvserver.objects.filter(servertype=serverid) context={'serverall':serverall,'types':types} return render(request,'aptest/servers.html',context)
方法二,先查询servers表,然后再通过外键查询pvserver表:
def servers(request,serverid): #serverid从下面的types中遍历出来,为了省事,才在该视图下使用types,其实types应该从另一个页面下使用 serverlist = serversm.objects.get(serverid=serverid) #from aptest.models import servers as serversm types = serversm.objects.all() #得出所有的服务器种类,在前端web展示 serverall = serverlist.pvserver_set.all() #根据服务器种类遍历出相应的服务器列表 context={'serverall':serverall,'types':types} return render(request,'aptest/servers.html',context)
4.编辑url:
url(r'^servers/(\d+)/$', aptest.servers),
5.访问http://192.168.50.74/aptest/servers/2/可以返回上图。