Django

news2024/11/24 20:50:31

文章目录

    • 基础知识
      • 创建项目
      • 启动项目
      • 创建超级用户
  • 创建项目
    • 构建个人博客网站
      • 简单构建
      • 开启本地虚拟环境
      • 初步创建blog应用
    • 常用的模板标签和过滤器
      • 注:常用的模板标签
      • 注:常用的过滤器
    • 模板嵌套
      • 全局模板文件夹
      • 模板文件设置建议
    • 使用css美化页面
      • 导航栏
      • 页面美化
    • css框架协助前端布局

基础知识

创建项目

选择你想放文件的文件夹,cmd进入
activate dj 进入虚拟环境
django-admin startproject 项目名
进入项目名
用pycharm打开你的文件
创建项目
打开之后就是这个样子的
打开项目
编写路由
路由
创建一个新的py项目命名为views
views文件

启动项目

输入命令python manage.py runserver
然后复制网址,打开浏览器查看
在这里插入图片描述
这个时候就代表你的项目创建并启动成功了
下面我们就开启进一步

创建超级用户

创建项目

构建个人博客网站

·明确创建的项目需要什么东西
例如:创建一个网站就需要明确网站的有哪些功能模块
网站的功能模块
明确每个功能模块是干嘛的。

简单构建

简单构建
·功能模块≈Django App

开启本地虚拟环境

隔开python项目的运行环境
1.避开多个项目之间python库的冲突
2.完整便捷导出python库的列表
下载包 pip install virtualenv
下载virtualenv
卸载django并创建虚拟环境
在这里插入图片描述
下载成功
在这里插入图片描述
这个时候去你的文件夹就可以看到
在这里插入图片描述
进入mysite_env
在这里插入图片描述
进入虚拟环境
进入虚拟环境
在此虚拟环境下安装django
注:我安装的是2.0版本的 django==2.0
django2.0
目前的包
在这里插入图片描述
退出虚拟环境再次查询有哪些包
在这里插入图片描述

初步创建blog应用

进入虚拟环境,创建项目mysite
创建项目
进入项目,创建appblog
在这里插入图片描述
mysite文件用编辑器打开(我这里用的pycharm)
在这里插入图片描述
models中写入两个类
关于博文和博客分类
在这里插入图片描述
对数据库进行初始化python manage.py migrate
对数据库进行初始化
创建超级管理员python manage.py createsuperuser
在这里插入图片描述
将应用添加进入mysite-->mysite-->settings
在这里插入图片描述
创建migrations目录python manage.py makemigrations 并更新数据库
这里创建了两个模型一个关联字段
在这里插入图片描述
admin中进行博客的文章显示框架管理
在这里插入图片描述
启动服务器python manage.py runserver
在这里插入图片描述
复制网址查看http://127.0.0.1:8000/admin
使用刚刚的账号密码登录
登录后就是下面的那个样子的
在这里插入图片描述
·可以改成中文显示zh-Hans
在这里插入图片描述
在这里插入图片描述
在BlogType中添加内容
在这里插入图片描述
如果出现以下报错

解决报错
首先将django的版本升级到2.1.7
然后将数据库进行删除
在这里插入图片描述
python manage.py makemigrations blog
python manage.py migrate
然后重新创建超级管理员
python manage.py runserver
然后进行添加
在这里插入图片描述
这里就有啦,我这儿添加了三个
在这里插入图片描述
然后添加博客文章内容
在这里插入图片描述
然后在models中写入函数
在这里插入图片描述
这个时候再刷新查看
就关联过来啦在这里插入图片描述
写一篇随笔
在这里插入图片描述
显示就是这个样子在这里插入图片描述
扩展:pip一键导出和安装(以后会用上的)
pip freeze > requirements.txt
pip install -r requirements.txt
在这里插入图片描述

常用的模板标签和过滤器

·继续搭建blog
在 blog文件下的views 中导入
from django.shortcuts import render_to_response 用模板页面输出内容响应
需要两个处理方法 def blog_list(request):请求对应的变量 是访问博客列表
def blog_detail(request,blog_pk): 是显示具体的blog也页面 说明 参数:blog_pk是需要传一个主键
在这里插入图片描述
注意这里的两个html文件是还没有写
在blog下面创建templates
然后在templates下面创建上面两个html文件
在这里插入图片描述
在这里插入图片描述
在blog中新建路由
在这里插入图片描述
总路由
在这里插入图片描述
然后运行python manage.py runserver
然后对html文件进行了修改
在这里插入图片描述
在这里插入图片描述
然后在超级管理员中添加一篇博客
在这里插入图片描述
添加标签统计使其可以一眼看到有多少条博客
方法一:

方法二:通过处理方法返回
在这里插入图片描述
在这里插入图片描述
可以发现两种方法可以达到同样的效果,但是也可以发现第一种明显要方便亿点点。所以这里果断选择方法一。
·但是如果我没有博客的话它的显示是不是0呢?
我们马上看一下,于是打开admin删除两篇博客
在这里插入图片描述
在这里插入图片描述
删除之后可以发现是会显示0篇的(两种方法都会)
在这里插入图片描述
这里我们还可以添加一句提示语暂无博客,敬请期待
添加代码如下
在这里插入图片描述
实现效果如下:
在这里插入图片描述
添加长篇博客查看
在这里插入图片描述
可以发现一长段的文本在这里显示的看着非常繁杂
在这里插入图片描述
太长了,我们让它只显示前30个字
代码如下
在这里插入图片描述
效果如下:
在这里插入图片描述
这里就更加简洁美观啦
在页面中添加其他内容(作者…)
在这里插入图片描述
显示效果:
在这里插入图片描述
使其显示博客类型并使博客类型变成超链接的形式
·添加路由
在这里插入图片描述
·添加试图函数
在这里插入图片描述
HTML文件在这里插入图片描述

在这里插入图片描述
此时,运行查看效果
在这里插入图片描述
问题是没有对应的关键字参数
在这里插入图片描述
此时运行发现还是有问题
在这里插入图片描述
检查发现我们视图函数中的变量名写错了,修改过后运行查看
在这里插入图片描述
点击分类之后就跳转到随笔了,因为我这里只添加了三篇随笔,所以显示的就是三篇随笔。

我又添加了一个感悟类型的博客
再次运行点击类型就可以发现类型下面只有同类型的文章

注:常用的模板标签

常用模板标签

注:常用的过滤器

常用过滤器

模板嵌套

模板的重复的很多
找个方法将重复的加载出来
基本模板文件(三个模板相似的地方)base.html
在这里插入图片描述
修改三个html文件(三个都一样,只需要将不同的内容添加进入模板即可)
blog_detial.html
在这里插入图片描述
blog_list.html
在这里插入图片描述
blogs_with_type.html
在这里插入图片描述
仍旧是可以运行的,这里的模板嵌套就完成啦

全局模板文件夹

路径为:settings --> TEMPLATES --> DIRS
在此目录下创建templates文件
在这里插入图片描述
将基础公共文件base.html迁移到刚刚创建的templates里面
在这里插入图片描述
重启应用

模板文件设置建议

app模板文件-->app
project模板文件-->project

跟着项目走的话放全局
封装的特别好的话app应用只跟app应用有关系就放在app里面就可以

这里我们就将其放在公共模板文件夹中
在这里插入图片描述
将三个模板文件重新创建的blog文件中去
在这里插入图片描述
修改views.py中的路径
在这里插入图片描述
这个时候查看网页显示的仍旧没有问题

使用css美化页面

一般的就可以设计成三个部分(可以根据自己的需求来做)
·导航栏
·主体内容
·尾注(可有可无)
在这里插入图片描述

导航栏

设计目标
·logo网站名称+导航
在这里插入图片描述
添加首页
mysite下面创建views.py文件并写入方法
在这里插入图片描述
在公共模板文件夹下面创建首页的html文件
在这里插入图片描述
修改app中的路由文件使其点击博客找到博客列表
在这里插入图片描述
修改project中的路由文件(总路由)
在这里插入图片描述
运行查看效果
在这里插入图片描述
在这里插入图片描述

页面美化

使用css
在这里插入图片描述
查看效果
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
显示效果
在这里插入图片描述
但是注意将HTML与css放在一起后面修改不是很方便
这里将css单独放在一个文件中css代码 --> css文件,这里的 css文件js文件图片统称为静态文件
静态文件就是写好了之后不会有太多变化的
在project下面创建一个静态文件夹static文件并将刚刚base.html文件中的css复制过来
在这里插入图片描述
settings中添加路径,使其可以找到你的静态文件
在这里插入图片描述
base.html文件中引用
在这里插入图片描述
运行查看效果
在这里插入图片描述
将home.html进行相同操作
在这里插入图片描述
在这里插入图片描述
实现相同效果

css框架协助前端布局

【对css不太会或者直接不会的】
这里选择的是Bootstrap

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/100168.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

捋一捋什么是MySQL插入意向锁?

Insert Intention Lock,中文我们也称之为插入意向锁。 这个可以算是对我们之前所讲的 Gap Lock 的一个补充,关于 Gap Lock,如果还有小伙伴不懂,可以参考:聊一聊MySQL的记录锁、间隙锁与 Next-Key Lock。 1. 为什么需…

Java基础之《netty(14)—异步模型》

一、基本介绍 1、异步的概念和同步相对。当一个异步过程调用发出后,调用者不能立刻得到结果。实际处理这个调用的组件在完成后,通过状态、通知和回调来通知调用者。 2、netty中的I/O操作是异步的,包括Bind、Write、Connect等操作会简单的返…

【云原生 | 47】etcdctl客户端的使用方法详解

🍁博主简介: 🏅云计算领域优质创作者 🏅2022年CSDN新星计划python赛道第一名 🏅2022年CSDN原力计划优质作者 🏅阿里云ACE认证高级工程师 🏅阿里云开发者社区专…

后台基础权限框架搭建实现[木字楠博客]

文章目录1、项目整合SpringSecurity1.1、引入SpringSecurity依赖1.2、启动测试1.3、自定义实体类继承UserDetails1.4、自定义配制文件1.5、重写loadUserByUsername方法1.6、自定义匿名访问注解1.8、编写SpringSecurity配制类后台权限框架搭建:本项目权限主要依赖Spr…

Polynomial Round 2022 (Div. 1 + Div. 2, Rated, Prizes!) A-C

比赛链接 目录 A. Add Plus Minus Sign 题意: 思路: 代码: B. Coloring 题意: 思路: 代码: C. Ice and Fire 题意: 思路: 代码: A. Add Plus Minus Sign 题意…

半导体芯片制造过程可以用哪种测量仪器

近年来,面对持续高涨的芯片需求,半导体行业生产迎来了高难度挑战——对芯片工艺要求更精细,从5nm到3nm,甚至是2nm。“先进封装”的提出,是对技术的新要求,也是对封装工艺中材料和设备的全新考验。 芯片身上…

节点电力市场生产商的战略竞标:凸松弛方法(Matlab实现)

目录 1 电力市场 1.1 什么是电力市场 1.2 电力市场发展历程 1.3 对传统电力系统理论的挑战 2 节点电力市场生产商的战略竞标:凸松弛方法 2.1 简介 2 Matlab代码 1 电力市场 1.1 什么是电力市场 市场:商品交换(交换商品的过程称交易)关系的总和 …

pikachu靶场验证码绕过详解

今天继续给大家介绍渗透测试相关知识,本文主要内容是pikachu靶场验证码绕过详解。 免责声明: 本文所介绍的内容仅做学习交流使用,严禁利用文中技术进行非法行为,否则造成一切严重后果自负! 再次强调:严禁对…

endo-BCN-PEG3-Biotin,endo-BCN三聚乙二醇-生物素

【中文名称】endo-BCN三聚乙二醇-生物素 【英文名称】 endo-BCN-PEG3-Biotin,BCN-PEG3-Biotin (endo) 【CAS号】1263166-92-2 【分子式】C29H46N4O7S 【分子量】594.77 【基团部分】BCN 【纯度标准】95% 【外观颜色】 白色固体 (具体由其分子量大小决定…

MyBatis学习 | 简介HelloWord

文章目录一、简介二、HelloWord2.1 环境搭建2.2 创建全局配置文件2.3 创建工具类2.4 创建数据库表和对应的JavaBean2.5 创建SQL映射文件2.6 非接口式与接口式编程2.6.1 非接口式编程2.6.2 接口式编程⭐2.7 简单总结学习地址🔗 https://www.bilibili.com/video/BV1mW…

动态规划问题——换钱的方法数

题目: 给定数组arr,arr中所有的值都为正数且不重复。每个值代表一种面值的货币,每种面值的货币可以使用任意张,再给定一个整数aim,代表要找的钱数,求换钱有多少种方法。 举例: arr [5, 10, 2…

【PCL1.11.0+win10+vs2019】环境配置/ 点云格式转换及可视化

文章目录一、安装1.1 下载PCL1.2 安装PCL1.3 安装OSGeo4W二、配置2.1 配置环境变量2.2 配置VS2019三、点云格式转换以及可视化参考一、安装 1.1 下载PCL 首先我们需要下载pcl1.11.0 ,这个版本与vs2019对应。 有两种下载方法:百度网盘、官网下载。二选一…

docker原理及服务编排

一、什么是docker Docker 是一个开源项目,诞生于2013年初,最初是dotCloud公司内部的一个业余项目。它基于Google公司推出的Go语言实现。项目后来加入了Linux基金会,遵从了Apache 2.0协议,项目代码在GitHub上进行维护。 Docker 项…

【毕业设计_课程设计】基于Spark网易云音乐数据分析

文章目录0 项目说明1 系统模块2 分析内容3 界面展示4 项目工程0 项目说明 基于Spark网易云音乐数据分析 提示:适合用于课程设计或毕业设计,工作量达标,源码开放 1 系统模块 包含爬虫,Scala代码,Spark,Hadoop,ElasticSearch,logstash,Flume…

基于ChatGPT实现微信智能机器人

ChatGPT近期以强大的对话和信息整合能力风靡全网,可以写代码、改论文、讲故事,几乎无所不能,这让人不禁有个大胆的想法,能否用他的对话模型把我们的微信打造成一个智能机器人,可以在与好友对话中给出意想不到的回应&am…

汇编语言笔记——接口技术与编程

文章目录传送门储存系统与技术材料高速储存器缓冲储存器(Cache)材料,局部性,访问方式Cache全相联映射Cache交换与一致性单核CPU一致性处理多核CPU的MESI协议主储存器(内存)主要技术指标容量带宽内存模组与内…

【JavaWeb】Servlet

Servlet简介 Servlet是sun公司开发动态web的一门技术Sun在这些API中提供一个接口叫做:Servlet,如果想开发一个Servlet程序,需要编写一个类,实现Servlet接口把开发好的Java类部署到web服务器中 把实现了Servlet接口的Java程序叫做…

【Anime.js】——Anime.js源码核心理解

一、Anime.js整体结构 Anime.js的强大之处在于代码量非常少,但功能却非常强大。让我们一起来探索Anime.js源码的核心吧~ Anime.js之所以能如此强大主要是因为它的代码结构设计的非常巧妙合理,所以我们想要掌握Anime.js的核心,首先我们要了解…

Linux内核基础篇——动态输出调试

文章目录配置内核编译选项debugfs文件系统挂载动态输出使用实际案例动态输出(dynamic print)是内核子系统开发者最喜欢的输出技术之一。 上篇说到printk调试,但printk是全局的,只能设置输出等级。而动态输出可以动态选择打开某个…

Tensorflow Serving部署推荐模型

Tensorflow Serving部署推荐模型 1、找到当前模型中定义的variables,并在此定义一个saver用于保存模型参数 def saveVariables(self):variables_dict {}variables_dict[self.user_embedding.op.name] self.user_embeddingvariables_dict[self.item_embedding.op…