bbs---点赞

需求分析

页面展示

  1 点赞  和   踩灭  按钮展示

1 用户未登录,不处理点赞踩灭,给用户提供登录接口

2 登录

  1 第一次点点赞/踩灭

    1 点赞成功 数据+1 提示点赞成功

    2点赞失败 数据+1 提示踩灭成功

  2 第二/n次点点赞/踩灭

    1 点击点赞/踩灭,提示已点赞/踩灭过 

代码思路

1 html页面结构

页面展示

1 在文章视图函数中传入从orm中查询到的该文章的对象

2 在html中,通过模板语法,取到点赞数和踩灭数

  点赞 {{ article.up_count }}

  踩灭 {{ article.up_count }}

用户点赞/踩灭

1 由于点击不能确定点赞还是踩灭,我们把点赞和踩灭绑定统一个事件--------通过绑定同一个类完成

2 判断用户有没有登录

  没登录:跳转到登录页面,并且把当前的url传过去,方便登录后跳转回来

  登录:执行下面的

3 获取 文章id  用户id 点赞/踩灭

  文章id '{{ article.id }}'

  用户id '{{ request.user.id }}'

  点赞/踩灭:通过获取点赞/踩灭特有的类,能否取到值来判断  然后通过三元运算 赋值 True /False

4 ajax通过post请求把数据传给后端

5 后端 赋值状态码 获取 文章id 用户id 点赞/踩灭状态

  文章id

  用户id

  点赞/踩灭状态:坑1

6 通过文章id 用户id 取值判断用户是否点赞/踩灭过

  未点赞/踩灭过

    赋值状态码 添加点赞/踩灭记录   跟新文章的点赞/踩灭字段  ----------这里要用事务

  点赞/踩灭过

    赋值状态码 和  错误信息 返回

坑:

  1 通过ajax 传的True/False 时‘True’/'False',所以我们要通过三元运算重新赋值True/Flase

实际操作

html

    <!-- 点赞 开始-->
<div class="clearfix">
<div id="div_digg">
<!-- 点赞 -->
<div class="diggit digg">
<span class="diggnum" id="digg_count">{{ article.up_count }}</span>
</div>
<!-- 反对 -->
<div class="buryit digg">
<span class="burynum" id="bury_count">{{ article.down_count }}</span>
</div>
<div class="clear"></div>
<!-- 提示信息 -->
<div class="diggword" id="digg_tips"></div>
</div>
</div>
<!-- 点赞 结束--> <script>
// 给点赞和反对按钮绑定点击事件
$(".digg").click(function () {
// 1. 先判断有没有登录?
if (!'{{ request.user.username }}') {
// 如果没有登录就跳转到登录页面
location.href = '/login/?next={{ request.get_full_path }}'
}
// 已经登录可以点赞或反对
var userId = '{{ request.user.id }}';
var articleId = '{{ article.id }}';
// 如何区分是点赞还是反对?
var isUp = $(this).hasClass('diggit');
// 向后端发请求
$.ajax({
url: '/mengmeng/',
type: 'post',
data: {
csrfmiddlewaretoken: $('[name="csrfmiddlewaretoken"]').val(),
userId: userId,
articleId: articleId,
isUp: isUp
},
success: function (res) {
console.log(res);
if (res.code !== 0) {
// 只需要把错误提示显示出来就可以
$("#digg_tips").text(res.msg);
} else {
// 1. 先把点赞数或反对数更新一下
if (isUp) {
// 更新点赞数
var $UpSpan = $("#digg_count");
$UpSpan.text(+$UpSpan.text() + 1);
} else {
var $downSpan = $("#bury_count");
$downSpan.text(+$downSpan.text() + 1)
}
// 2. 再显示提示
$("#digg_tips").text(res.msg);
}
}
})
});
</script>

views

# 点赞
def mengmeng(request):
if request.method == "POST":
res = {"code": 0}
print(request.POST)
user_id = request.POST.get("userId")
article_id = request.POST.get("articleId")
is_up = request.POST.get("isUp")
print(is_up, type(is_up))
is_up = True if is_up.upper() == 'TRUE' else False
# 5.不能给自己点赞
article_obj = models.Article.objects.filter(id=article_id, user_id=user_id)
if article_obj:
# 表示是给自己写的文章点赞
res["code"] = 1
res["msg"] = '不能给自己的文章点赞!' if is_up else '不能反对自己的内容!' # 3.同一个人只能给同一篇文章点赞一次
# 4.点赞和反对两个只能选一个
# 判断一下当前这个人和这篇文章 在点赞表里有没有记录
is_exist = models.ArticleUpDown.objects.filter(user_id=user_id, article_id=article_id).first()
if is_exist:
res["code"] = 1
# 表示已经点赞过或反对过
# if is_exist.is_up == True:
# # 已经点过赞
# res["msg"] = '已经点过赞'
# else:
# # 已经反对过
# res["msg"] = '已经反对过' res["msg"] = '已经点过赞' if is_exist.is_up else '已经反对过'
else:
# 真正点赞
# 注意?
# 事务操作,,
with transaction.atomic():
# 1. 先创建点赞记录
models.ArticleUpDown.objects.create(user_id=user_id, article_id=article_id, is_up=is_up)
# 2. 再更新文章表
if is_up:
# 更新点赞数
models.Article.objects.filter(id=article_id).update(up_count=F('up_count')+1)
else:
# 更新反对数
models.Article.objects.filter(id=article_id).update(down_count=F('down_count') + 1)
res["msg"] = '点赞成功' if is_up else '反对成功'
return JsonResponse(res)

bbs--点赞的更多相关文章

  1. BBS项目分布搭建四(点赞点踩及评论功能准备)

    BBS项目分布搭建四(点赞点踩及评论功能) 1. 点赞点踩样式准备 # 在base.html文件中 head标签内 添加css模块: {% block css %} {% endblock %} # ...

  2. python自动化开发-[第二十二天]-bbs多级评论、点赞、上传文件

    今日概要: 1.related_name和related_query_name的区别 2.through_fields的用途 3.django的事务提交 4.点赞的动画效果 5.多级评论的原理 6.上 ...

  3. bbs项目实现点赞和评论的功能

    一.点赞功能 思路是这样的: 1.对点赞和踩都设置一个相同的class,然后对这个class绑定点击事件 2.点击触发ajax请求,我们对赞的标签设置了一个class属性,对踩的标签没有设置这个cla ...

  4. BBS - 文章详细页、点赞、踩灭

    一.文章详细页 文章详细页:1.链接:<div><h5><a href="/blog/{{ article.user.username }}/articles/ ...

  5. BBS论坛 文章详情、点赞、评论

    六.文章详情.点赞.评论 文章详情页面: def article_detail(request, username, article_id): # user_obj = models.UserInfo ...

  6. day74 bbs项目☞点赞与评论

    目录 一.文章详情展示 1 将侧边栏做成inclusion_tag 二.点赞点踩功能 三.评论功能 整体总结: 在出现bug的时候,先判断是前端bug还是后端bug,再判断bug错误类型,以及报错信息 ...

  7. [deviceone开发]-心形点赞动画示例

    一.简介 这个示例展示do_Animator组件的简单使用,通过点击"点赞"按钮,不断弹出心形图片,向上动画漂移到顶部消失.间隔时间和上下左右移动的步长都是一定范围的随机值.二.效 ...

  8. Python之路【第十八篇】Django小项目简单BBS论坛部分内容知识点

    开发一个简单的BBS论坛 项目需求: 整体参考“抽屉新热榜” + “虎嗅网” 实现不同论坛版块 帖子列表展示 帖子评论数.点赞数展示 在线用户展示 允许登录用户发贴.评论.点赞 允许上传文件 帖子可被 ...

  9. python 学习笔记二十 django项目bbs论坛

    项目:开发一个简单的BBS论坛 需求: 整体参考“抽屉新热榜” + “虎嗅网” 实现不同论坛版块 帖子列表展示 帖子评论数.点赞数展示 在线用户展示 允许登录用户发贴.评论.点赞 允许上传文件 帖子可 ...

  10. [deviceone开发]-直播APP心形点赞动画示例

    一.简介 这个示例展示do_Animator组件的简单使用,通过点击"点赞"按钮,不断弹出心形图片,向上动画漂移到顶部消失.间隔时间和上下左右移动的步长都是一定范围的随机值. 二. ...

随机推荐

  1. MyBatis学习存档(5)——联表查询

    之前的数据库操作都是基于一张表进行操作的,若一次查询涉及到多张表,那该如何进行操作呢? 首先明确联表查询的几个关系,大体可以分为一对一和一对多这两种情况,接下来对这两种情况进行分析: 一.建立表.添加 ...

  2. 【kmp】似乎在梦中见过的样子

    参考博客: BZOJ 3620: 似乎在梦中见过的样子 [KMP]似乎在梦中见过的样子 题目描述 「Madoka,不要相信QB!」伴随着Homura的失望地喊叫,Madoka与QB签订了契约. 这是M ...

  3. cygwin gcc 编译windowsAPI 报错的一个解决方案

    一开始按照linux的习惯去编译一个使用了windowsAPI的程序 结果提示: $ i686-pc-cygwin-g++ screen_catch.cscreen_catch.c: In funct ...

  4. 华为精益敏捷专家:DevOps转型中的那些坑

    陈军--原腾讯高级项目经理.华为精益敏捷专家 DevOps是现在非常流行的一个词,很多人都在提DevOps,在往那个方向去转,但转的时候坑特别多. 现实是很理想的,大家都觉得做了DevOps之后就会非 ...

  5. hdu 1269 入手强连通

    思路待整理 #include<cstdio> #include<iostream> #include<cstring> #include<vector> ...

  6. 通过ADB调试安卓程序

    ADB,即 Android Debug Bridge,它是Android开发/测试人员不可替代的强大工具. 1.下载ADB后,将以下四个文件放到某个文件夹下即可.因为打开Cmd默认路径是 C:\Use ...

  7. 启动tomcat提示某个端口被占用

    原文参见:https://www.cnblogs.com/liuyanxia/p/6755520.html 解决办法 找出占用1099端口的进程,进入windows命令,查看什么进程占用了1099端口 ...

  8. 小程序page中生命周期

    onLoad -- 页面被加载出来 onShow -- 页面显示出来后  退出后两小时进来,只会执行这个生命周期 onRady -- (逻辑层传给渲染层后才会执行)监听页面初次渲染完成 onHide ...

  9. 【小知识点】去除inline-block元素间间距的办法

    之前一直用float浮动方法布局,因为display:inline-block有间隙,现在找到办法了.在父元素上面加font-sise:0,就可以了. 效果如图: 代码如下: <!DOCTYPE ...

  10. kali linux 安装 qq (deepin-wine)

    添加deeepin-wine 依赖 /etc/apt/sources.list: # Generated by deepin-installer deb http://mirrors.aliyun.c ...