Bootstrap

点击锁定按钮,锁定按钮要变成解锁按钮,然后状态要从待绑定变成 已锁定(升级版)

点击锁定按钮,锁定按钮要变成解锁按钮,然后状态要从待绑定变成 已锁定:https://blog.csdn.net/m0_65152767/article/details/144810693

这篇博客中的内容,有一个bug,那就是我刷新页面,解锁按钮还是会变成锁定按钮,最后检查发现锁定按钮有一个字段是和后端关联的,我没有更新后端这个字段的值,所以也就造成我们只是临时的更改锁定按钮的状态,并没有持久化更改。


1、updateInviteCodeStatus

// 修改接口参数类型
export const updateInviteCodeStatus = (data: {
    inviteCodeId: number;
    statusName: string;
    isLocked: number; // 新增 isLocked 字段
  }) =>
  request({
    url: '/api/invite-codes/updateStatus',
    method: 'put',
    params: data, // params 中包含 isLocked 参数
  });

2、handleLock

  private async handleLock(row: any) {
    const newIsLocked = row.isLocked === 0 ? 1 : 0
    const newStatus = newIsLocked === 0
      ? InviteCodeStatus.EFFECTIVE.name
      : InviteCodeStatus.LOCKED.name

    this.$confirm(
      `确定要${row.isLocked === 0 ? '锁定' : '解锁'}该邀请码吗?`,
      '提示',
      {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning'
      }
    )
      .then(async() => {
        try {
          console.log('请求参数:', {
            inviteCodeId: row.id,
            statusName: newStatus,
            isLocked: newIsLocked, // 添加 isLocked 参数
          })

          // 调用后端的更新状态接口
          const response = await updateInviteCodeStatus({
            inviteCodeId: row.id,
            statusName: newStatus,
            isLocked: newIsLocked, // 添加 isLocked 参数
          })

          console.log('response.data:', response.data)
          console.log('typeof response.data', typeof response.data)

          if (response && response.data && typeof response.data === 'object' && 'status' in response.data) {

            const status = response.data.status
            const isLocked = response.data.isLocked

            // 调试步骤 1:打印状态值
            console.log('状态值:', status)
            console.log('后端返回的isLocked值:',isLocked)

            // 调试步骤 2:检查状态映射
            let statusObj
            try {
              statusObj = InviteCodeStatus.fromValue(status)
              console.log('映射后的状态:', statusObj)
            } catch (e) {
              console.error('状态映射错误:', e)
              this.$message.error('状态映射错误,请联系管理员')
              return
            }

            // 更新本地数据
            const index = this.tableData.findIndex(item => item.id === row.id)
            if (index !== -1) {
              this.$set(this.tableData, index, {
                ...this.tableData[index],
                // isLocked: newIsLocked,
                status: status, // 使用后端返回的 status 值
                isLocked: isLocked, // 使用后端返回的isLocked
              })
              console.log('更新后的行数据:', this.tableData[index])
            }

            this.$message.success(`${newIsLocked === 0 ? '解锁' : '锁定'}成功`)

            // 选择性地重新拉取数据,根据实际需求
            // await this.fetchInviteCodeList();
          } else {
            this.$message.error('更新失败')
          }
        } catch (error) {
          console.error('更新邀请码状态失败:', error)
          console.error('错误详情:', error.response || error.message)
          this.$message.error('更新邀请码状态失败:未知错误')
        }
      })
      .catch(() => { })
  }

3、InviteCodeController

    @PutMapping("/updateStatus")
    public BaseResult updateInviteCodeStatus(
            @RequestParam Integer inviteCodeId,
            @RequestParam String statusName,
            @RequestParam Integer isLocked) {  // 添加 isLocked 参数
        try {
            // 获取 InviteCodeStatus 枚举值
            InviteCodeStatus status = InviteCodeStatus.fromName(statusName);
            // 调用service层更新状态的方法
            inviteCodeService.updateInviteCodeStatus(inviteCodeId, status.getValue(),isLocked);// 更新 isLocked
            // 获取更新后的邀请码数据
            Optional<InviteCode>  updatedInviteCodeOptional = inviteCodeService.getInviteCodeById(inviteCodeId);
            if(updatedInviteCodeOptional.isPresent()){
                InviteCode updatedInviteCode =  updatedInviteCodeOptional.get();
                // 构建返回数据
                Map<String,Object> data = new HashMap<>();
                data.put("status", updatedInviteCode.getStatus());
                data.put("isLocked", updatedInviteCode.getIsLocked()); // 添加 isLocked 字段
                return BaseResult.success("状态更新成功",data);
            }else {
                return BaseResult.success("状态更新成功");
            }
        } catch (IllegalArgumentException e) {
            return BaseResult.failure(BaseResult.PARAMETER_ERROR, e.getMessage());
        } catch (Exception e) {
            e.printStackTrace();
            return BaseResult.failure(500, "服务器内部错误" + e.getMessage());
        }
    }

4、InviteCodeService

    @Transactional
    public void updateInviteCodeStatus(Integer inviteCodeId, Integer status, Integer isLocked) {
        Optional<InviteCode> inviteCodeOptional = inviteCodeRepository.findById(inviteCodeId);
        if (inviteCodeOptional.isPresent()) {
            InviteCode inviteCode = inviteCodeOptional.get();
            inviteCode.setStatus(status);
            inviteCode.setLastModifiedDate(LocalDateTime.now());// 更新最后修改时间
            inviteCode.setIsLocked(isLocked);
            inviteCodeRepository.save(inviteCode);
        } else {
            throw new IllegalArgumentException("Invalid inviteCode ID: " + inviteCodeId);
        }
    }
    
    public Optional<InviteCode> getInviteCodeById(Integer inviteCodeId) {
        return inviteCodeRepository.findById(inviteCodeId);
    }

5、CrudRepository

public interface CrudRepository<T, ID> extends Repository<T, ID> {
			Optional<T> findById(ID var1);
			
			<S extends T> S save(S var1);
}

在这里插入图片描述

;