本项目基于B站UP主‘神奇的老黄’的教学视频‘天天生鲜Django项目’,视频讲的非常好,推荐新手观看学习

https://www.bilibili.com/video/BV1vt41147K8?p=1

实现功能为:

在商品详情页面,选择想要购买的数量,点击“加入购物车”按钮,实现右上角的购物车数量增加,并且页面其他信息保持不变。

一般处理按钮点击后,需要重新查询刷新整个页面的信息,但是很多需求只是刷新局部或一小部分信息,因此可以通过发送Ajax请求实现,注意ajax请求都是在后台运行的,前台不会展示运行的过程。

Ajax请求过程为:

1. 前端页面发起ajax请求(这里使用jQuery)将数据传递给后端

2. 后端执行请求地址相对应的视图函数,返回json内容

3. ajax执行相应的回调函数。接收返回的json数据并执行后续操作

编辑详情页面的前端js代码

1、jQuery获取标签元素对象为:$('.classname')

2、获取子标签:$('.classname').children('标签名')

3、获取文本内容为:.text()

4、获取值属性为:.val()

5、设置标签值为在获取值的方法中加入参数,该参数就是想要设置成为的值

6、注意点击事件如果想要调用其他的方法,不能直接写成.click(function_name()),还是得写成.click(function (){function_name()}),即在匿名方法中再调用其他的方法

7、isNaN() 函数可用于判断其参数是否是 NaN,该值表示一个非法的数字。

8、发起Ajax请求写法,$.post('/cart/add/', parameter, function(data){....}) 第一个参数为请求提交的地址,第二个参数为传给后台的数据,第三个参数为回调函数,即后台处理完成后,会调用这个回调函数,参数data为后台返回的数据,在回调函数中,使用返回的数据重新设置页面的部分数据

{% block endfiles %}
<div class="add_jump"></div> <script type="text/javascript" src="{% static 'js/jquery-1.12.4.min.js'%}"></script>
<script type="text/javascript">
//计算总价
update_goods_amout()
function update_goods_amout(){
//获取单价
price = $('.show_pirze').children('em').text()
//获取数量
count = $('.num_show').val()
//计算总价
amount = price * count
//刷新界面总价
$('.total').children('em').text(amount.toFixed(2)+'元')
}
//加号点击事件
$('.add').click(function(){
calculate(1)
})
//减号点击事件
$('.minus').click(function(){
calculate(-1)
})
//加减数量
function calculate(num){
//获取原数量
count = $('.num_show').val()
//+-1
count = parseInt(count) + num
if (count <=0){
count = 1
}
//刷新界面
$('.num_show').val(count)
//更新总价
update_goods_amout()
}
//手动输入商品数量
$('.num_show').blur(function(){
//获取数量
count = $(this).val()
//校验数量,
if (isNaN(count) || count.trim().length==0 || parseInt(count) <=0){
//刷新数量
count = 1
$(this).val(parseInt(count))
}
//更新总价
update_goods_amout()
})
//获取add_cart div元素左上角的坐标
var $add_x = $('#add_cart').offset().top;
var $add_y = $('#add_cart').offset().left;
//获取show_count div元素左上角的坐标
var $to_x = $('#show_count').offset().top;
var $to_y = $('#show_count').offset().left; //点击加入购物车的click事件
$('#add_cart').click(function(){
//获取数量
count = $('.num_show').val()
//获取商品ID,手动给加入购物车按钮新增一个属性goods_id
goods_id = $(this).attr('goods_id')
//csrf验证信息
csrf = $('input[name="csrfmiddlewaretoken"]').val()
//组织参数
parameter = {
'goods_id': goods_id,
'count': count,
'csrfmiddlewaretoken': csrf
}
//发起Ajax请求,第三个参数function为回调函数
$.post('/cart/add/', parameter, function(data){
if (data.status == 'S'){
//添加成功
//购物车加入成功的动态效果
$(".add_jump").css({'left':$add_y+80,'top':$add_x+10,'display':'block'})
$(".add_jump").stop().animate(
{'left': $to_y+7,
'top': $to_x+7},
"fast",
function() {
$(".add_jump").fadeOut('fast',function(){
//刷新右上角购物车数量
$('#show_count').html(data.cart_count);
});
});
}
else{
//添加失败
alert(data.errmsg)
}
})
}) </script>
{% endblock endfiles %}

编辑请求提交的URL

编辑cart应用的urls.py文件

from django.urls import path
from .views import CartView, CartAddView urlpatterns = [
path('add/', CartAddView.as_view(), name='add'),
path('', CartView.as_view(), name='cart'),
]

编辑处理请求的类视图

编辑cart应用的view.py文件

1、这里判断用户是否登录时,是手动写的校验,而不是像user应用中继承LoginRequiredMixin,原因是因为如果继承了LoginRequiredMixin,谷歌浏览器按F12打开后台运行情况查看,后台确实会访问重定向到的登录页面,但是由于这里提交的是Ajax请求,前台并不会跳转成登录页面,所以用户体验来说是这个跳转是无效的。

2、获取前台传过来的商品和数量,校验成功后,将其添加至购物车redis数据库中,然后返回新的购物车数据

3、返回的是JsonResponse对象,返回值内容为json格式

from django.views.generic import View
from django.http import JsonResponse
from goods.models import Goods
from django_redis import get_redis_connection class CartAddView(View):
'''加入购物车处理视图'''
def post(self, request):
user = request.user
context = {
'status': 'E',
'errmsg': ''
}
# 判断是否登录
if not user.is_authenticated:
context['errmsg'] = '用户未登录!'
return JsonResponse(context) # 接收数据
goods_id = request.POST.get('goods_id')
count = request.POST.get('count') # 校验数据
# 数据是否完整
if not all([goods_id, count]):
context['errmsg'] = '数据不完整!'
return JsonResponse(context)
# 商品是否存在
try:
goods_id = int(goods_id)
goods = Goods.objects.get(id=goods_id)
except Exception as e:
context['errmsg'] = '用户未登录!'
return JsonResponse(context)
# 数量格式是否正确
try:
count = int(count)
except Exception as e:
context['errmsg'] = '商品数量格式不正确!'
return JsonResponse(context) # 逻辑处理:添加购物车
# 连接redis
connect = get_redis_connection('default')
cart = 'cart_%d'%(user.id)
# 获取原购物车中goods_id的数量
old_count = connect.hget(cart, goods_id)
if old_count:
count += int(old_count)
# 判断是否超过库存
if count > goods.onhand:
context['errmsg'] = '超出库存数量!'
return JsonResponse(context)
# 将新数量保存至数据库
connect.hset(cart, goods_id, count)
# 获取新购物车数量
cart_count = connect.hlen(cart) # 返回数据
context['status'] = 'S'
context['cart_count'] = cart_count
return JsonResponse(context)

DJANGO-天天生鲜项目从0到1-009-购物车-Ajax实现添加至购物车功能的更多相关文章

  1. django天天生鲜项目

    .后台admin管理天天生鲜商品信息 models里 from django.db import modelsfrom tinymce.models import HTMLField #需要pip安装 ...

  2. DJANGO-天天生鲜项目从0到1-007-首页静态化与缓存

    本项目基于B站UP主‘神奇的老黄’的教学视频‘天天生鲜Django项目’,视频讲的非常好,推荐新手观看学习 https://www.bilibili.com/video/BV1vt41147K8?p= ...

  3. python 天天生鲜项目

    python 天天生鲜项目 django版:https://github.com/Ivy-1996/fresh flask版:https://github.com/Ivy-1996/flask-fre ...

  4. Django之天天生鲜项目

    准备工作 1.配置settings.py内置文件 注意: AUTH_USER_MODEL配置参数要在第一次迁移数据库之前配置,否则可能django的认证系统工作不正常 2.创建应用 3.配置主路由 一 ...

  5. DJANGO-天天生鲜项目从0到1-012-订单-用户订单页面

    本项目基于B站UP主‘神奇的老黄’的教学视频‘天天生鲜Django项目’,视频讲的非常好,推荐新手观看学习 https://www.bilibili.com/video/BV1vt41147K8?p= ...

  6. DJANGO-天天生鲜项目从0到1-011-订单-订单提交和创建

    本项目基于B站UP主‘神奇的老黄’的教学视频‘天天生鲜Django项目’,视频讲的非常好,推荐新手观看学习 https://www.bilibili.com/video/BV1vt41147K8?p= ...

  7. DJANGO-天天生鲜项目从0到1-010-购物车-购物车操作页面(勾选+删改)

    本项目基于B站UP主‘神奇的老黄’的教学视频‘天天生鲜Django项目’,视频讲的非常好,推荐新手观看学习 https://www.bilibili.com/video/BV1vt41147K8?p= ...

  8. DJANGO-天天生鲜项目从0到1-009-搜索功能实现(django-haystack+whoosh+jieba)

    本项目基于B站UP主‘神奇的老黄’的教学视频‘天天生鲜Django项目’,视频讲的非常好,推荐新手观看学习 https://www.bilibili.com/video/BV1vt41147K8?p= ...

  9. DJANGO-天天生鲜项目从0到1-006-首页-内容展示

    本项目基于B站UP主‘神奇的老黄’的教学视频‘天天生鲜Django项目’,视频讲的非常好,推荐新手观看学习 https://www.bilibili.com/video/BV1vt41147K8?p= ...

随机推荐

  1. Zookeeper分布式过程协同技术 - 部署及设置

    Zookeeper分布式过程协同技术 -  部署及设置 Zookeeper支持单机模式.伪集群模式.集群模式三种部署方式.演示部署环境为CentOS.jdk版本为1.8.Zookeeper版本为3.4 ...

  2. MongoDB快速入门教程 (2)

    2.MongoDB的基本的CRUD操作 2.1.创建文档 在具体操作之前,想要知道有多少数据库,可以执行下面命令 show dbs 在mongodb中,数据库中包含的叫做集合(表),集合中存储的内容叫 ...

  3. 《UNIX环境高级编程》(APUE) 笔记第一章 - UNIX基础知识

    1 - UNIX基础知识 Github 地址 1. 操作系统 可将操作系统定义为一种软件,它控制计算机硬件资源,提供程序运行环境.通常将这种软件称为 内核 (kernel) .( Linux 是 GN ...

  4. 【Spring注解驱动开发】如何使用@Value注解为bean的属性赋值,我们一起吊打面试官!

    写在前面 在之前的文章中,我们探讨了如何向Spring的IOC容器中注册bean组件,讲解了有关bean组件的生命周期的知识.今天,我们就来一起聊聊@Value注解的用法. 项目工程源码已经提交到Gi ...

  5. nginx配置奇怪问题记录

    执行  nginx -t  检查配置报了如下错误: 下面是配置信息 遇到个很奇怪的问题,plm-api-stage 这么配置就可以正常校验过,但是改成 plm-stage-api,就会上面的警告信息: ...

  6. Python3笔记006 - 2.3 变量

    第2章 python语言基础 python语法特点 保留字与标识符 变量 数据类型 运算符 输入和输出 2.3 变量 在python中,不需要先声明变量类型,直接赋值即可创建各种类型的变量. 1.定义 ...

  7. Web前端开发未来的六大趋势

    说起Web前端开发想必你一定不会陌生,因为现在的前端开发学习的培训机构也是层出不穷.下面济南优就业IT培训给大家总结出了未来Web前端开发的六大趋势从中可以大致看出来Web前端未来的发展前景. 趋势一 ...

  8. P1220 关路灯——区间dp

    P1220 关路灯 题目描述 某一村庄在一条路线上安装了 \(n\) 盏路灯,每盏灯的功率有大有小(即同一段时间内消耗的电量有多有少).老张就住在这条路中间某一路灯旁,他有一项工作就是每天早上天亮时一 ...

  9. UVA11300 Spreading the Wealth 题解

    题目 A Communist regime is trying to redistribute wealth in a village. They have have decided to sit e ...

  10. CTF_show平台 web题解 part2

    web10 WITH ROLLUP 绕过 点击取消键弹出源码下载: 源码如下: <?php $flag=""; function replaceSpecialChar($st ...