返回顶部
首页 > 资讯 > 后端开发 > Python >Springboot+Vue+axios实现文章收藏功能
  • 213
分享到

Springboot+Vue+axios实现文章收藏功能

2024-04-02 19:04:59 213人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

最近在做毕设,也是第一次使用前后分离框架我就边学边用SpringBoot+Vue做了一个博客文章的收藏功能,写得不好见谅,算是一个学习笔记吧,给大家分享一下,后面可能还会做一个关注/

最近在做毕设,也是第一次使用前后分离框架我就边学边用SpringBoot+Vue做了一个博客文章的收藏功能,写得不好见谅,算是一个学习笔记吧,给大家分享一下,后面可能还会做一个关注/粉丝的模块。

那就进入正题:

咱们就先从数据库出发

id_blog主要就是关联对应的文章,id_user就是是谁对这个文章收藏了,这样后续利于用户查询自己收藏的文章列表,create_time可以加上添加时间,这个字段后续可进行按照时间排序

数据库创建好后,就写实体类

@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
public class BloGCollection implements Serializable {

    private static final long serialVersionUID = 1L;

    @TableId(value = "id", type = IdType.AUTO)
    private Integer id;

    private Integer idBlog;

    private Integer idUser;

    @JSONFORMat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField(fill = FieldFill.INSERT)
    private LocalDateTime createTime;
}

Mapper

public interface BlogCollectionMapper extends BaseMapper<BlogCollection> {
    @Insert("insert into 表名  values(字段名)")
    void addCollection(BlogCollection bc);
    //可以用mybatisPlus插入数据方便
}

Service

public interface BlogCollectionService extends IService<BlogCollection> {
    void addCollection(BlogCollection bc);
}

serviceImpl

public class BlogCollectionServiceImpl extends ServiceImpl<BlogCollectionMapper, BlogCollection> implements BlogCollectionService {

    @Autowired
    BlogCollectionMapper blogCollectionMapper;
    @Override
    public void addCollection(BlogCollection bc) {
        blogCollectionMapper.addCollection(bc);
    }
}

Controller

@RestController
@RequestMapping("/BlogCollection")
public class BlogCollectionController {
    @Resource
    BlogCollectionService blogCollectionService;
    @Resource
   BlogCollectionMapper BlogCollectionMapper;
    //收藏
    @PostMapping("/addBlogCollection")
    public Result<?> addBlog(@RequestBody BlogCollection blogCollection) {
        blogCollectionService.addCollection(blogCollection);
        return Result.success();
    }
}

以上就是添加收藏的部分代码,然后就是写前端调用及渲染到页面上

<div class="button_content" style="flex: 1;line-height: 60px">
   <el-button @click="addCollection" v-if="collectionState===false" type="text" style="margin-left: 30px">
      <el-icon style="font-size:20px" color="#999aaa"><StarFilled /></el-icon>
       {{collectionCount }}
          </el-button>
          <el-button @click="delCollection" v-if="collectionState===true" type="text" style="margin-left: 30px">
            <el-icon style="font-size:20px" color="#999aaa"><StarFilled /></el-icon>
            {{collectionCount }}
          </el-button>
          <el-button type="text" @click="" style="margin-left: 30px">
            <el-icon style="font-size:20px" color="#999aaa"> <ChatDotRound /></el-icon>
            {{ messageCount }}
  </el-button>
</div>

js部分

 data(){
    return{
    collectionIds:{},
    collectionState:false,//默认是false则是可收藏,true的话就是已收藏
    }
    },
    methods:{
    add(){
      this.collectionIds.idBlog=this.$route.query.id //当前文章ID
      this.collectionIds.idUser=this.user.id //当前用户ID
    request.post("/BlogCollection/addBlogCollection",this.collectionIds).then(res=>{
        if (res.code === '0') {
          this.$message({
            message: "收藏成功",
            type: "success"
          });
          this.collectionState=true
          console.log(this.collectionState)
        } else {
          this.$message({
            message: res.msg,
            type: "error"
          });
        }
      })
    }
    }

在页面加载时获取该用户判断是否收藏该文章

getState(){
      let userJson=sessionStorage.getItem("user")
      let userid=JSON.parse(userJson).id
      request.get("/user/getState/"+userid).then(res=>{
        if(res.data!=null){        //从表中查询是否有记录,不为空把collectionState设置true
          this.collectionState=true
        }
        if(res.data.length){  //获取结果集如果存在则把collectionState设置true,防止重复收藏
          this.collectionState=true
        }
      })
    },

获取用户收藏状态需要在页面加载时调用,需要在created里进行调用,其次就是取消收藏功能也是跟这个逻辑一样的,在点击取消收藏后将collectionState设置为false即可,后台的话就通过用户id对收藏表查询删除就可以啦!奉上效果图:

未收藏状态

已收藏状态

补充:request是axiOS封装的一个工具,大家也可以使用原axios进行对后台接口调用

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: Springboot+Vue+axios实现文章收藏功能

本文链接: https://lsjlt.com/news/166430.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Springboot+Vue+axios实现文章收藏功能
    最近在做毕设,也是第一次使用前后分离框架我就边学边用springboot+vue做了一个博客文章的收藏功能,写得不好见谅,算是一个学习笔记吧,给大家分享一下,后面可能还会做一个关注/...
    99+
    2024-04-02
  • SpringBoot实现物品收藏功能
    前后端分离项目–二手交易平台小程序 SpringBoot----物品点赞功能实现 SpringBoot----评论回复功能实现(数据库设计) SpringBoot----文件(图片)...
    99+
    2024-04-02
  • java实现收藏功能
    本文实例为大家分享了java实现收藏功能的具体代码,供大家参考,具体内容如下 需求分析 分析: 1.要求用户必须登录,否则提示2.第一次点击,表示收藏成功,收藏数+1,显示蓝色星星...
    99+
    2024-04-02
  • vue+axios+java实现文件上传功能
    本文实例为大家分享了vue+axios+java实现文件上传的具体代码,供大家参考,具体内容如下 背景 vue.js + axios + element前端,Java后台实现的文件上...
    99+
    2024-04-02
  • jQuery实现文章收起与展开功能
    本文实例为大家分享了jQuery实现文章收起与展开功能的具体代码,供大家参考,具体内容如下 废话不多说,直接上代码 <!DOCTYPE html> <html ...
    99+
    2024-04-02
  • vue实现文章点赞和差评功能
    本文实例为大家分享了vue实现文章点赞和差评功能的具体代码,供大家参考,具体内容如下 纯前端实现文章点赞与差评(支持与不支持)。 需求:状态1:用户没有操作过,即既没点赞和差评;状态...
    99+
    2024-04-02
  • Vue实现文本展开收起功能
    本文实例为大家分享了Vue实现文本展开收起功能的具体代码,供大家参考,具体内容如下 先说说需求,以及实现的需求 1、移动端H5,发表留言后跳转到评论列表,超过5行文字,多余的需要隐藏...
    99+
    2024-04-02
  • vue使用axios接收流文件的实现
    在工作中遇到使用axios接收流文件,遇到了一些问题,整理如下: 在调用接口成功后如图所示: 现在需要调试下axios.js文件统一拦截 // 导出 const heade...
    99+
    2022-11-13
    vue axios接收流文件 vue 接收流文件
  • SpringBoot+Vue+Axios+BootStrap实现图书的增删改查功能示例
    目录一、开发工具二、项目结构三、编写项目四、运行项目由于是初学Vue、Axios,可能在界面和功能上存在着一些问题,但这些并不妨碍使用。如果有对编程感兴趣的朋友,可以试着做一做。这个...
    99+
    2024-04-02
  • redis如何实现收藏功能设计
    Redis可以通过使用有序集合来实现收藏功能的设计。具体步骤如下:1. 创建两个有序集合,一个用于存储用户收藏的内容,另一个用于存储...
    99+
    2023-08-31
    redis
  • springboot+vue实现登录功能
    本文实例为大家分享了springboot+vue实现登录功能的具体代码,供大家参考,具体内容如下 目录结构 前端端口:8080 后端端口:8900 login.vue <...
    99+
    2024-04-02
  • VUE+SpringBoot实现分页功能
    本文主要介绍一下 Vue + SpringBoot 中如何实现一个分页列表数据。 1、效果展示 2、VUE代码 VUE之视图定义 <el-row> ...
    99+
    2024-04-02
  • vue+springboot实现登录功能
    本文实例为大家分享了vue+springboot实现登录功能的具体代码,供大家参考,具体内容如下 1. 登录功能的实现 实现提交表单的代码如下: async submitForm...
    99+
    2024-04-02
  • springboot+vue实现验证码功能
    本文实例为大家分享了springboot+vue实现验证码功能的具体代码,供大家参考,具体内容如下 1.工具类 直接用不用改 package com.example.demo.U...
    99+
    2024-04-02
  • jquery中ztree如何实现右键收藏功能
    这篇文章主要为大家展示了“jquery中ztree如何实现右键收藏功能”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“jquery中ztree如何实现右键收藏功能...
    99+
    2024-04-02
  • Windows7 库功能把文件收藏起来
    在Windows XP时代,文件管理的主要形式是以用户的个人意愿,用文件夹的形式作为基础分类进行存放,然后再按照文件类型进行细化。但随着文件数量和种类的增多,加上用户行为的不确定性,原有的文件管理方式往往会造成文件存储混...
    99+
    2023-05-25
    Windows7 库功能 文件
  • vue+springboot+shiro+jwt实现登录功能
    目录1.导入依赖2.JWTToken 替换 Shiro 原生 Token3.JWT token 工具类,提供JWT生成、校验、获取token存储的信息4.JWTFilter请求拦截5...
    99+
    2024-04-02
  • SpringBoot+Vue实现数据添加功能
    一、添加代码生成器 用来自动为数据库映射类建立:mapper、service、controller 注:代码生成器的写法,参考官方文档:https://mp.baomidou.co...
    99+
    2024-04-02
  • springboot+vue如何实现登录功能
    小编给大家分享一下springboot+vue如何实现登录功能,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!目录结构前端端口:8080后端端口:8900login.vue<template> &nbs...
    99+
    2023-06-15
  • Android开发中使用sqlite实现新闻收藏和取消收藏的功能
     之前学习oracle,简单的认为数据库只存在服务器端,学习安卓之后才发现原来android和Ios本身是“携带”数据库的——SQLite,是轻量级的、嵌入式的、关系...
    99+
    2022-06-06
    android开发 SQLite Android
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作