logo 范 · 拾光录
网址收集 关于作者 Github Gitee
杂文随笔5
Hexo博客:基础使用Hexo博客:Next主题Hexo博客:Next进阶使用Hexo博客:Next高级配置基于Node的WIKI管理
前端知识16
HTML常用知识CSS常用知识CSS美化checkbox复选框JavaScript常用知识JavaScript格式化时间戳JavaScript窗口宽高处理JavaScript黑夜主题切换实现方案JavaScript数字转大写简易图片查看器TypeScript基础知识Threejs基础三要素Threejs网格辅助和轨道控制器Threejs物体绘制Electron基础使用Nodejs基础知识animate.css页面动画
Vue框架19
Vite的使用及扩展Vue3父子组件Vue3使用Marked解析MarkdownMermaid图表生成库初始化页面加载动画Axios表单提交二维码解决方案NProgress加载进度条Vue3动态菜单实现Vue3使用ECharts图表Vue3处理Excel导入导出keep-alive页面缓存及setup问题Element:文件上传Element:结合Pinia实现动态菜单Element:图片上传组件Element:自定义统一弹窗组件Element:表格自定义指令控制按钮显示(鉴权)可视化大屏使用缩放适配分辨率
UniApp15
UniApp的基础使用封装网络请求工具及文件上传uni-app的开发记录微信小程序分享原生文件上传Pinia取消滚动条(兼容小程序)tabbar消息数量显示scroll-view上滑到底部加载数据状态栏高度动态设配数据共享与传递uview-plus导航栏实现背景融合Wot UIWot UI实现顶部背景图融合uni-app x
Java基础知识10
基础知识面向对象Lambda表达式常用API常用知识积累try-with-resource注解反射多线程经纬度距离计算
SpringBoot31
application配置Maven创建聚合项目全局异常处理锁机制项目启动初始化数据方式邮件功能集成原生定时任务异步集成阿里云OSS阿里OSS预签名上传基于hutool读excelJSR303WebSocketWebSocket版AI接口流式调用Smart-Doc接口文档生成器application配置信息加密雪花算法工具AOP实现请求参数脱敏思路JWT生成Token及工具类SpringBoot默认JSON与对象转换若依框架:安装使用若依框架:优化和调整文件上传若依框架:管理后台页面优化若依框架:后端接口代码优化SpringAISpringBoot实现AI接口流式调用服务启动时创建MySQL连接自建项目工程树形结构处理工具微信支付代码微信手机号登录
SpringMVC14
跨域处理拦截器RESTful风格伪前后端分离Jackson转换器调整Thymeleaf基于拦截器做权限校验AOP打印接口请求响应日志AOP打印接口请求响应耗时文件上传和回显POST请求加解密实现(AES)POST请求加解密实现(RSA+AES)参数动态校验实现方案真实IP和归属地
MyBatis8
MyBatis基本使用与配置Mapper使用相关MaBatis多数据源配置MyBatisPlus数据统计类处理方案MyBatisPlus条件查询正向工程的实现(H2)mybatis-plus-join
SpringCloud15
Netflix:微服务与搭建Netflix:服务的消费与提供Netflix:EurekaNetflix:ActuatorNetflix:RibbonNetflix:FeignNetflix:HystrixNetflix:ZuulAlibaba:简介与搭建Alibaba:Nacos注册中心Alibaba:RibbonAlibaba:OpenFeignAlibaba:Nacos配置中心Alibaba:GetewayAlibaba:Sentinel
MySQL6
MySQL基础知识MySQL多表查询与事务MySQL常用函数及解决方案MySQL视图MySQL索引安装MySQL
Redis7
Redis介绍和安装Redis配置文件Redis持久化Redis集群Redis语法基础Redis相关问题及解决方案SpringBoot集成Redis使用记录
MongoDB10
Linux安装MongoDBMongoDB基础语法MongoTemplate及SpringBoot配置MongoTemplate中Update操作MongoTemplate中聚合查询MongoTemplate日期归档示例项目使用相关知识归纳地理位置存储与距离查询MongoDB副本集与事务获取类名和属性名工具类
其他数据库1
H2数据库
Python编程6
Python基础知识Python语法yolo目标检测OpenCV的使用及树莓派平台condauv
工具集合13
IDEAMavenGradleGitNginx安装Nginx配置VSCodeJMeter压测DockerOllamaRustFSPicGoObs录制
Linux知识11
Linux常用命令Jar启动脚本VirtualBox安装CentOSVirtualBox安装Ubuntu树莓派安装及使用frp内网穿透ArchLinux:基础系统安装ArchLInux:图形化界面安装ArchLinux:常用软件ArchLinux:深度优化ArchLinux:Niri
创意设计2
Blender:入门知识UI设计基础知识
AI相关9
Claude CodeHermes AgentOpenAI基本使用OpenAI工具调用OpenAI记忆管理OpenAI推理执行OpenAI开发框架Langchainllama.cpp

单图片上传组件

ImageOneComponent.vue

<!-- 单图片上传 -->
<!-- 注意修改上传接口、Token -->
<template>
  <div>
    <el-upload
      class="avatar-uploader"
      :action="api + '/manage/file/upload'"
      :headers="{ token: store.token }"
      :show-file-list="false"
      :on-success="imageUploadSuccess"
      :before-upload="imageUploadBefore">
      <el-image
        v-if="mv"
        class="avatar"
        style="width: 178px; height: 178px"
        :src="mv"
        fit="cover" />
      <el-icon v-else class="avatar-uploader-icon">
        <Plus />
      </el-icon>
    </el-upload>
  </div>
</template>

<script setup>
import { ref, getCurrentInstance, watch } from 'vue'
// 注意store的位置,这里用的Pinia,注意名称
import { sysStore } from '../store'
import { Plus } from '@element-plus/icons-vue'
// 这里是多环境配置中的接口地址
let api = import.meta.env.env_http_api
// 名称需要与Pinia导出一致
const store = sysStore()

const props = defineProps({
  modelValue: {
    type: String,
    default: ''
  }
})
const mv = ref(props.modelValue)
const { emit } = getCurrentInstance()
watch(
  () => props.modelValue,
  () => {
    mv.value = props.modelValue
  }
)

// 图片上传前
function imageUploadBefore() {}

// 图片上传成功
function imageUploadSuccess(res) {
  console.log(res)
  emit('update:modelValue', res.data)
}
</script>

<style scoped lang="scss">
.avatar-uploader {
  border: 1px dashed var(--el-border-color);
  border-radius: 6px;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  width: 178px;
  height: 178px;
  transition: var(--el-transition-duration-fast);

  img {
    width: 100%;
  }
}

.avatar-uploader:hover {
  border-color: var(--el-color-primary);
}

.el-icon.avatar-uploader-icon {
  font-size: 20px;
  color: #8c939d;
  width: 178px;
  height: 178px;
  text-align: center;
}
</style>

使用方式

import ImageOneComponent from './ImageOneComponent.vue'

<ImageOneComponent v-model="modifyData.req.cover" />

多图片上传组件

ImageMoreComponent.vue

<!-- 多图片上传,适用于英文逗号分隔的字符串 -->
<!-- 注意修改上传接口、Token -->
<template>
  <div>
    <el-upload
      :action="api + '/manage/file/upload'"
      :headers="{ token: store.token }"
      v-model:file-list="fileList"
      list-type="picture-card"
      :on-success="imageUploadSuccess"
      :before-upload="imageUploadBefore">
      <el-icon class="avatar-uploader-icon">
        <Plus />
      </el-icon>
    </el-upload>
  </div>
</template>

<script setup>
import { ref, getCurrentInstance, watch } from 'vue'
// 注意store的位置,这里用的Pinia,注意名称
import { sysStore } from '../store'
import { Plus } from '@element-plus/icons-vue'
// 这里是多环境配置中的接口地址
let api = import.meta.env.env_http_api
// 名称需要与Pinia导出一致
const store = sysStore()

const props = defineProps({
  modelValue: {
    type: String,
    default: ''
  }
})

const fileList = ref([])

// 将 modelValue 字符串转为 fileList 数组
function parseModelValue(val) {
  if (!val) return []
  return val.split(',').map((url) => ({
    name: url,
    url
  }))
}

// 初始化 fileList
fileList.value = parseModelValue(props.modelValue)

const { emit } = getCurrentInstance()
watch(
  () => fileList.value,
  (newVal) => {
    const urls = newVal.map((file) => file.url).join(',')
    emit('update:modelValue', urls)
  },
  { deep: true }
)

// 图片上传前
function imageUploadBefore() {}

// 图片上传成功回调
function imageUploadSuccess(res) {
  if (res.code === 200) {
    // 添加新文件对象到 fileList
    fileList.value.push({
      name: 1,
      url: res.data
    })
    // 过滤name不为1的图片
    fileList.value = fileList.value.filter((item) => item.name === 1)
    console.log(fileList.value)
  }
}
</script>

<style scoped lang="scss">
// 清除动画效果
::v-deep .el-upload-list__item {
  transition: none !important;
}
/* 无效就移动到全局 */
/* 多图上传,关闭预览功能和删除文字提示 */
.el-upload-list__item-preview,
.el-icon--close-tip {
  display: none !important;
}
/* 多图上传,调整删除图片居中 */
.el-upload-list__item-delete {
  margin-left: 0 !important;
}
</style>

使用方式

import ImageMoreComponent from './ImageMoreComponent.vue'

<ImageMoreComponent v-model="modifyData.req.images" />

大文件

https://help.aliyun.com/zh/oss/user-guide/upload-files-using-presigned-urls#7de0f0f8414ze

https://blog.csdn.net/qq_39842184/article/details/146481497

单图片上传组件
使用方式
多图片上传组件
大文件