第一个真正意义的Django项目 !
预计时间5天  20190309--20190314
目标:学会Django的使用,理解模块关系!
 
querset  相当于一个存放列表的字典
day1 20190309 
1.1 引入环境 ,配置static静态文件,并引入 bootstrap下的dist文件和 jquery
STATIC_URL = '/static/'
STATICFILES_DIRS=[os.path.join(BASE_DIR,'static')]
这样下次引入时,会一直使用路径别名  /static/ ,需注意的是项目启动时是以manage.py文件为原始目录来查找路径,而自己测试html时是以该文件的路径为原始路径。
创建了超级用户 yeteng/yeteng123
1.2 创建和删除用户
#生成新用户,修改状态表
newuser=User.objects.create_user(username=username,password=password,email=email)
# # 删除用户的操作
# deluser = User.objects.get(id=2)
# deluser.delete()
1.3bootstrap中的居左和居右

1、pull-left和pull-right

2、text-left、text-center和text-right
1.4  三个简单实用的用于 DOM 操作的 jQuery 方法:
  • text() - 设置或返回所选元素的文本内容  --其他标签
  • html() - 设置或返回所选元素的内容(包括 HTML 标记) --其他标签
  • val() - 设置或返回表单字段的值   -- 对应input  textarea输入标签

day2 20190313
2.1 modles.py 中定义表class时的blank与null 区别
blank:
当blank=True时,说明此处的数据可以不填,默认情况下为False,也就意味着默认情况下,所输入的数据不得空,blank是和页面表单 有关,在页面需要输入参数的时候,如果在models里面定义了blank=True时,那么这个参数是可以不填写的,如果是默认的话,如果没有填写,则会提示错误。
null:
当null=True时,也就是说如果没有填写数据,此处用NULL来储存空值,默认的是null=False。
总结:blank主要是用在CharField, TextField,这两个字符型字段可以用空字符穿来储存空值。
null主要是用在IntegerField,DateField, DateTimeField,这几个字段不接受空字符串,所以在使用时,必须将blank和null同时赋值为True。
顺便一提,在设置BooleanField为空时,可以使用NullBooleanField型字段。     
2.2 在通过AbstractUser类创建用户类时,可添加自定义字段,同时必须注意的是继承该类必须在setting.py中声明使用,一旦指定了新的认证系统使用的表,必须重新在数据库中创建该表,不能使用原来的auth_user表
# 引用Django自带的User表,继承使用时需要设置
AUTH_USER_MODEL = "APP名.UserInfo"
django.db.migrations.exceptions.InconsistentMigrationHistory
查看了网上其他博客后:大多建议删除 django_migrations表并删除migration目录下的0001_initial.py(并不能解决问题):
因为当你重新迁移是,并不能成功的映射新的数据库表:
这里只有删除main下除sqlite_master和sqlite_sequence表下的其他表然后重新执行
python manage.py makemigrations
python manage.py migrate
才能迁移成功:
Django中删除和重建数据库中关于models类的映射数据库表的正确方法:
在Django中删除models类的映射数据库表需要在models.py中剪切或删除对应的models类:然后在控制台中执行:
python manage.py makemigrations(Django会重新对照你的models类与数据库中的映射表,如果你的model类被删除,则Django会生成一个删除迁移)
python manage.py migrate(执行删除迁移,删除数据库中对应的model映射表)
原文:https://blog.csdn.net/follow_sunshine/article/details/81485222
day3 20190314
 
在 admin界面可以看到注册的表,需配置 admin.py文件
from django.contrib import admin
from blog import models

# Register your models here.
# 注册后可在 前端admin直接查看
admin.site.register(models.Blog)
admin.site.register(models.Category)
admin.site.register(models.Article)
admin.site.register(models.ArticleDetail)
admin.site.register(models.Tag)
admin.site.register(models.Article2Tag)

 
<!-- 注意html这里取一个列表的第几个值,直接 .数字就可以,如 list.1 ;list[1]会报错 -->
django.template.exceptions.TemplateSyntaxError: Could not parse the remainder: '[0]' from 'cate[0]'
annotate 会将查询结果全部字段作为group by 内容 ,括号里的函数作为select对象.
例如:     models.values("AAA").annotate.(C=count(artid)).values("BBB")
对应SQL:  select "AAA|BBB的查询字段",count(artid) as C from tab1,tab2 ..
               where xxxxxxxxxx
               group by "AAA|BBB的查询字段"
有一个坑,如果 "AAA|BBB的查询字段" 包括了 artid,那么分组结果往往不是你想要的,注意剔除掉

day4 20190315
python(Django之html模板继承) 
关键字:extends   block

链接:  https://www.cnblogs.com/lei0213/articles/6410410.html
day5 20190316
 
关于Django中修改js css文件但浏览器无法及时与之改变的问题
https://blog.csdn.net/g11d111/article/details/79032287
浏览器——> 设置——> 高级——>清除浏览数据 ——> 清除缓存和图片,即可
事物:transaction    不用前端序列化的json:JsonResponse
def diggit(request):
    from django.db import transaction
    from django.db.models import F
    from blog import models

print("diggit---------------11111")
    if request.is_ajax():
        article_id=request.POST.get("article_id")

print(request.user.username,article_id,"-----")
        user=request.user
        article=models.Article.objects.filter(articleid=article_id)
        art_state={"state":False}
        # 在点赞表中加一个 用户和文章的记录,同时文章表的点赞数+1,这两个是事物
        try:
            with transaction.atomic():
                # 方法一
                models.ArticleUpDown.objects.create(user_id=user.userid,article_id=article_id)
                # 方法二
                # models.ArticleUpDown.objects.create(user=user,article=article[0])
                article.update(up_count=F("up_count")+1)
                art_state={"state":True}
        except:
            pass

# django 下的json,在前端不需要反序列化
    from django.http import JsonResponse

return JsonResponse(art_state)
点击跳转到其他盒子的方法:
方法一HTML5中a标签的锚点使用  通过id跳转  
<a href="#d3">我在找OA系统</a><br/>
https://blog.csdn.net/chanzhi2016/article/details/80003393
 
方法二,js下id获取焦点方法   $("#d3").focus() 
day6 20190317
事件委派  jquery下的on方法(原生js语法不一样):
on(事件类型,标签<.class,#id,标签>,委派的方法):
好处:1.如果子标签较多,不用一个个for循环加事件,消耗内存,增加程序处理的个数
2.新添加的子标签将会直接获得事件,如博客添加的新评论,直接将事件放在父级,新加的评论ajax到页面马上拥有相关事件。
1  $(function(){
2             $("#lists").on("click","li",function(event){
3                 var target = $(event.target);
4                 target.css("background-color","red");
5             })
6         })
Django模板中的数字自增
https://www.bbsmax.com/A/1O5EB0Bbd7/
forloop.counter

--------------------end! --------------------------------------------cnblog项目--20190309

转载于:https://www.cnblogs.com/yeteng/p/10554442.html

cnblog项目--20190309相关推荐

  1. 2015年2月12日——不懂点

    CNBLOG项目不懂知识点: 1. local:[...]的写法 +  这样声明可使用. 1 xmlns:local="using:CNBlogs" 2 xmlns:Control ...

  2. Alpha版本项目展示

    团队成员的简介和个人博客地址 团队成员照片 团队成员介绍 李文涛(左二) 我是福建人,但是长得比较高,就显得有点逗 我就是个典型的逗逼青年,我平时的爱好就看书.看剧.上上网什么的 为什么说我逗逼呢?因 ...

  3. iOS_CNBlog项目开发 (基于博客园api开发) 上篇

    按照惯例, 先上效果图 前言 做这个项目是因为刚好在逛博客园的时候看到一篇文章 博客园第三方客户端-i博客园正式发布App Store, 这里就帮忙贴下链接吧. 整个项目做下来大概做了半个月, 今天算 ...

  4. .NET Core实战项目之CMS 第十四章 开发篇-防止跨站请求伪造(XSRF/CSRF)攻击处理...

    通过 ASP.NET Core,开发者可轻松配置和管理其应用的安全性. ASP.NET Core 中包含管理身份验证.授权.数据保护.SSL 强制.应用机密.请求防伪保护及 CORS 管理等等安全方面 ...

  5. [转]2020年排名前20的基于SpringBoot搭建的开源项目,帮你快速进行项目搭建!

    △Hollis, 一个对Coding有着独特追求的人△ 这是Hollis的第 287 篇原创分享 作者 l Hollis 来源 l Hollis(ID:hollischuang) SpringBoot ...

  6. 基于 CODING 的 Spring Boot 持续集成项目

    本文作者:CODING 用户 - 廖石荣 持续集成的概念 持续集成(Continuous integration,简称 CI)是一种软件开发实践,即团队开发成员经常集成他们的工作,通常每个成员每天至少 ...

  7. Scrapy学习篇(三)之创建项目

    创建项目 创建项目是爬取内容的第一步,之前已经讲过,Scrapy通过scrapy startproject <project_name>命令来在当前目录下创建一个新的项目. 下面我们创建一 ...

  8. [转]2020 年最具潜力 44 个顶级开源项目,涵盖 11 类 AI 学习框架、平台(值得收藏)

    导语:​Github 开源项目技术图 雷锋网 AI 开发者按:工欲善其事必先利其器,这也是大部分开发者在日常工作中最重要开发原则.选择与开发内容相匹配的工具,常常会使我们事半功倍.但面对人工智能的多个 ...

  9. 科普无穷小微积分是最大的知识共享项目

    J.Keisler撰写的"无穷小微积分"(共计14章,100多个微积分主题,992页面),遵循知识共享推广协议,每年服务于数百万青年学子,社会意义十分巨大. 袁萌本人不是知识共享协 ...

最新文章

  1. 软件测试实验--数据工厂DataFactory+MySQL数据构造
  2. HTML5 Canvas 基础API和实例
  3. 第十天2017/04/21(2、泛型编程:模板 / 全特化、偏特化)
  4. 销毁Bean的基本操作有哪些?
  5. 12.JAVA基本数据类型
  6. 比以前更帅气了的飞鸽传书
  7. 中小学教育培训类织梦模板
  8. ubuntu 下LAMP服务器环境搭建
  9. vue 内的 对象 获取 键值对_vue.js - vue 登录存localStorage的方法
  10. 大型网站技术架构(二)--架构模式(转)
  11. Atitit 信息检索 之音乐检索实践 艾提拉注 目录 1. 常规检索 歌手 歌名 1 1.1. 年代检索 1 1.2. 歌词检索(可以依靠web 1 1.3. 哼唱检索 原曲检索(可以使用酷
  12. Java工具集-农历日期工具类
  13. 数据蜂巢架构演讲之路读后感
  14. Oracle system表空间用满解决
  15. XCel 项目总结 - Electron 与 Vue 的性能优化
  16. DAO年终盘点:光环加身,道阻且长 |链捕手
  17. 智力题:13 个球一个天平,现知道只有一个和其它的重量不同,问怎样称才能用三次就找到那个球?
  18. 系统工程(SE)学习笔记(四)——系统架构设计
  19. Linux shell脚本中分号的作用
  20. REST协议解密(原创)

热门文章

  1. HTML5 Canvas 旋转
  2. Python 技术篇-socket套接字实现两个窗口间消息传递实例演示,TCP实现
  3. Python 技术篇-使用pygame库展示界面添加图片不显示问题解决办法
  4. 操作系统中的零拷贝与java中的使用
  5. STM32下SD卡驱动详解
  6. CTFshow 反序列化 web269
  7. real--复数的实数部分
  8. 【论文阅读】Clustering by Shift
  9. C++(Windows下计算时间变化(时间差))
  10. 玛塔机器人函数_玛塔创想编程机器人套装包含什么?