当前位置: 首页 > news >正文

wordpress官方网站重庆大足网站建设

wordpress官方网站,重庆大足网站建设,WordPress文章如何折叠插件,东莞网站建设专业品牌一、创建模型 模型是表示我们的数据库表或集合类#xff0c;并且其中所述类的每个属性是表或集合的字段#xff0c;在 app/models.py 中定义。 1、首先#xff0c;导入models模块 from django.db import models 接下来创建个学生信息类#xff0c;其中包含学生姓名、性别…一、创建模型 模型是表示我们的数据库表或集合类并且其中所述类的每个属性是表或集合的字段在 app/models.py 中定义。 1、首先导入models模块 from django.db import models 接下来创建个学生信息类其中包含学生姓名、性别、年龄、入学时间、家庭住址等信息 class Students(models.Model):name models.CharField(verbose_name学生姓名, max_length50)sex models.CharField(verbose_name性别, max_length50)age models.IntegerField(verbose_name年龄)address models.CharField(verbose_name家庭住址, max_length250, blankTrue)enter_date models.DateField(verbose_name入学时间)remarks models.TextField(verbose_name备注, blankTrue) 在终端内执行这两个数据库修改同步的命令 python3 manage.py makemigrations python3 manage.py migrate 现在看看数据库已经有了这张我们已经创建好的表及相关字段 2、创建好数据表之后接下来要将数据模型展示到页面 首先将app/admin.py文件重命名为adminx.py并导入模块 import xadmin from .models import * 在前面我们已经创建好了一张包含学生姓名、性别、年龄、入学时间、家庭住址等信息的数据表现在如果想要让其中的学生姓名、性别、年龄、入学时间显示在界面上那就要创建一个类其中的 list_display 属性包含需要展示在页面的相关字段 class StudentsAdmin(object):list_display (name, sex, age, address,) 最后对其进行注册 xadmin.site.register(Students, StudentsAdmin) 来看看页面长得是这样子的 3、本地化语言显示 是否发现左侧栏目显示的还是Students咦不对怎么会是Students呢原因就在于英文单词有单数和复数之分左侧这一栏默认是以类名最后加s作为复数显示的。那我们想要把它改为中文要怎么做呢接下来就来操作 在models.py的Students类下添加类属性 class Students(models.Model):name models.CharField(verbose_name学生姓名, max_length50)sex models.CharField(verbose_name性别, max_length50)age models.IntegerField(verbose_name年龄)address models.CharField(verbose_name家庭住址, max_length250, blankTrue)enter_date models.DateField(verbose_name入学时间)remarks models.TextField(verbose_name备注, blankTrue)class Meta:verbose_name 学生信息verbose_name_plural 学生信息def __str__(self):return self.name 4、下拉选项 到这里我们会发现在添加学生信息的时候其中有一个性别字段每次都要手动输入“男”/“女”要是弄成下拉选择框那就省事了有办法 在Students类里添加 SEX ((male, 男),(female, 女)) 然后修改sex字段 修改前 sex models.CharField(verbose_name性别, max_length50) 修改后 sex models.CharField(choicesSEX, verbose_name性别, max_length50) 同时记得对模型的修改操作凡是有涉及到数据库的都要进行同步操作运行命令 python3 manage.py makemigrations python3 manage.py migrate *有了学生信息之后还需要添加个学生所属的班级信息。同样的在models.py里添加一个班级类 class Class(models.Model):class_name models.CharField(verbose_name班级, max_length100)class Meta:verbose_name 班级verbose_name_plural 班级def __str__(self):return self.class_name *注意这两个类必须写在Students类的上面否则无法被Students类识别 还是一样修改adminx.py对这两个类进行注册和页面自定义展示操作 class ClassAdmin(object):list_display (class_name,)xadmin.site.register(Class, ClassAdmin) 这里我们先把班级信息给填写完整之后需要对Students类关联这这两张表 *外键的操作 在Students类里添加 grade_name models.ForeignKey(Grade, verbose_name所在年级, on_deletemodels.CASCADE, blankTrue, nullTrue)class_name models.ForeignKey(Class, verbose_name所在班级, on_deletemodels.CASCADE, blankTrue, nullTrue) 这里的ForeignKey代表使用外键用到的是我们上面创建好的年级和班级这两张表的信息blankTrue和nullTrue代表可以为空非必填字段。 使用数据库同步命令 python3 manage.py makemigrations python3 manage.py migrate 学生需要有他要学习的课程现在我们就来创建课程的数据表同样的需要写在学生表前面 models.py文件内添加 class Subjects(models.Model):name models.CharField(verbose_name课程名称, max_length50, blankTrue)score models.IntegerField(verbose_name学分, blankTrue)class Meta:verbose_name 课程信息verbose_name_plural 课程信息def __str__(self):return self.name adminx.py文件内添加 class SubjectsAdmin(object):list_display (name, score,)xadmin.site.register(Subjects, SubjectsAdmin) *多对多关系 一个学生需要选修的课程一般不少于1门那就需要用到多对多关系 修改Student类添加一个选修课程字段 subjects models.ManyToManyField(Subjects, verbose_name选修课程) 同步一下数据库信息方法前面提到这里不再赘述。 我们看到的选修课程的选项似乎有点丑而且一旦选择了就无法取消。这就需要对adminx.py进行修改自定义显示风格 在StudentsAdmin内中添加一个内联复选框 style_fields {subjects: checkbox-inline, } 这里要注意一个地方刚才我们在Students类中创建subjects字段时没有设置其为非必填字段这里就会导致必须勾选了所有选项之后才让保存。所以正确的做法应该是要修改Students中的subjects字段加入blankTrue subjects models.ManyToManyField(Subjects, verbose_name选修课程, blankTrue) xadmin2.0貌似有个bug这里本来应该显示横排的复选框但是却显示成了竖着的在Django1.xxadmin0.6的组合里使用显示是正常的 有了学生之后我们再来创建教师信息表 models.py文件中加入 class Teachers(models.Model):name models.CharField(verbose_name教师姓名, max_length50)class Meta:verbose_name 教师信息verbose_name_plural 教师信息def __str__(self):return self.name adminx.py文件中加入 class TeachersAdmin(object):list_display (name,)xadmin.site.register(Teachers, TeachersAdmin) 不要忘记了同步数据库。 *一对一关系 假设学校规定一个教师只能担任一个班级的班主任那就需要用到一对一关系 修改models.py的Class表添加headmaster字段 headmaster models.OneToOneField(Teachers, verbose_name班主任, on_deletemodels.CASCADE, blankTrue, nullTrue) 这里的OneToOneField就是一对一关系了执行数据库同步命令。 现在在页面上的班级信息里选择班主任一个班主任在被一个班级选定之后其他班级是无法再选择的 具体源码内容  请关注学长公众号回复“Django”   公众号二维码
http://www.huolong8.cn/news/123308/

相关文章:

  • 网站页面那个图怎么做科技期刊
  • 广东哪有做网赌网站网站备案省份
  • 给别人做网站能赚钱吗上海房地产网站建设报价
  • 河北区网站建设icp备案官网查询
  • 网站代备案公司名称青岛做网站建设价格
  • 一套企业网站设计图片怀化 优化营商环境
  • 东莞凤岗做网站网站推广是怎么推广的
  • 网站建设二公司中国空间站成为全人类太空之家
  • 自己免费做网站(三)高校网站建设制度
  • 西安网站排名优化培训网站的优化什么做
  • seo网站推广有哪些如何在网站投放广告
  • 网站 会员管理营销模板WordPress
  • 赣州网站建设方案网站开发页面静态化技术
  • 贵州做网站kuhugz怎样把网站建设在国外
  • 专业的网站首页建设公司公章电子版在线制作
  • 如何做网课网站怎么样做淘宝优惠券网站
  • 手机网站用什么语言开发公司营销网站建设
  • 平面设计和网站运营外贸网站建设加推广
  • 天津网站建设价格国内做免费的视频网站有哪些
  • 一个网站需要多少网页代做关键词收录排名
  • 沧浪手机网站建设方案wordpress能用的插件吗
  • 网站建设代码怎么导入图片找人做网站都需要提供什么
  • 江永网站建设中国五大门户网站
  • 具有品牌的福州网站建设广州昨天发生重大新闻
  • 创新驱动发展战略的内容关键词排名优化免费
  • 做环卫车怎么做网站游戏交易网站开发
  • 中英网站模板做外卖系统哪家网站做的好
  • 网页qq登录记录网站长春推广公司
  • 网站建设公司成都做网站要学的东西
  • 英文自助建站东台网站开发