选项方案1.请求方式
参数名类型是否必传说明2.请求参数:JSON
字段说明3.响应结果:JSON
class UserBrowseHistory(LoginRequiredJSONMixin, View): """用户浏览记录""" def post(self, request): """保存用户浏览记录""" # 接收参数 json_dict = json.loads(request.body.decode()) sku_id = json_dict.get('sku_id') # 校验参数 try: models.SKU.objects.get(id=sku_id) except models.SKU.DoesNotExist: return http.HttpResponseForbidden('sku不存在') # 保存用户浏览数据 redis_conn = get_redis_connection('history') pl = redis_conn.pipeline() user_id = request.user.id # 先去重 pl.lrem('history_%s' % user_id, 0, sku_id) # 再存储 pl.lpush('history_%s' % user_id, sku_id) # 最后截取 pl.ltrim('history_%s' % user_id, 0, 4) # 执行管道 pl.execute() # 响应结果 return http.JsonResponse({'code': RETCODE.OK, 'errmsg': 'OK'})2. 查询用户浏览记录4.后端接口定义和实现
选项方案1.请求方式
无2.请求参数:
字段说明3.响应结果:JSON
class UserBrowseHistory(LoginRequiredJSONMixin, View): """用户浏览记录""" def get(self, request): """获取用户浏览记录""" # 获取Redis存储的sku_id列表信息 redis_conn = get_redis_connection('history') sku_ids = redis_conn.lrange('history_%s' % request.user.id, 0, -1) # 根据sku_ids列表数据,查询出商品sku信息 skus = [] for sku_id in sku_ids: sku = models.SKU.objects.get(id=sku_id) skus.append({ 'id': sku.id, 'name': sku.name, 'default_image_url': sku.default_image.url, 'price': sku.price }) return http.JsonResponse({'code': RETCODE.OK, 'errmsg': 'OK', 'skus': skus})4.后端接口定义和实现
<div class="has_view_list" v-cloak> <ul class="goods_type_list clearfix"> <li v-for="sku in histories"> <a :href="sku.url"><img :src="sku.default_image_url"></a> <h4><a :href="sku.url">[[ sku.name ]]</a></h4> <div class="operate"> <span class="price">¥[[ sku.price ]]</span> <span class="unit">台</span> <a href="javascript:;" class="add_goods" title="加入购物车"></a> </div> </li> </ul></div>Vue渲染用户浏览记录
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) | 黑马程序员IT技术论坛 X3.2 |