Vue3——自定义封装上传图片样式

简介: 自定义封装上传图片样式

自定义封装上传图片样式

一、首先需要新建一个自组建完善基础的结构,我这里起名为ImgUpload.vue

<el-upload name="file" 
           :show-file-list="false" 
           accept=".png,.PNG,.jpg,.JPG,.jpeg,.JPEG,.gif,.GIF,.bmp,.BMP" :multiple="false" 
           :http-request="uploadImgage">
</el-upload>

name 上传的文件字段名

show-file-list 是否显示已上传文件列表

accept 接受上传的文件类型(thumbnail-mode 模式下此参数无效)

multiple 是否支持多选文件

http-request 覆盖默认的 Xhr 行为,允许自行实现上传文件的请求

二、接下来自定义背景以及图标

<el-upload name="file" :show-file-list="false" accept=".png,.PNG,.jpg,.JPG,.jpeg,.JPEG,.gif,.GIF,.bmp,.BMP"
    :multiple="false" :http-request="uploadImgage">
    <!-- 这里定义上传样式-->
    <div class="cover-upload-btn">
      <template v-if="modelValue">
        <img :src="proxy.globaInfo.imageUrl + modelValue" alt="">
      </template>
      <i v-else class="iconfont icon-jia"></i>
    </div>
  </el-upload>

判断如果存在路径则显示图片,否则显示默认背景

样式如下:

.cover-upload-btn {
  width: 150px;
  height: 150px;
  position: relative;
  border: 1px solid #DCDFE6;
  border-radius: 5%;
  padding: 5px;
  box-sizing: border-box;
  img{
    width: 100%;
  }
  i {
    position: absolute;
    top: 50%;
    left: 50%;
    font-size: 46px;
    transform: translate(-50%, -50%);
    color: #aaa;
  }
}

样式效果如下:

5d794bfd92754205b6ec13ad97b05287.png

三、上传方法

const uploadImgage = async(file) => {
    console.log(file);
    // 请求接口中需要带url以及
    let result = await proxy.Request({
        url:api.uploadUrl,  // 上传路径
        dataType:'file', // 指定传输类型
        params:{
            file:file.file,   // 提交上传路径到指定位置
            type:0,          
        }
    })
    const fileName = result.data.fileName
    emit('update:modelValue',fileName) 
};

dataType可以参考这段封装请求的requset

f76b2ece7d7943d8a503b0e56a391b74.png

前面配置的代码部分如下:

import { getCurrentInstance } from "vue";
const {proxy} = getCurrentInstance()
// 通过props将路径传给父组件
const props = defineProps({
    modelValue:{
        type:String,
        default:null
    }
})
const api = {
    uploadUrl:'/img' //图片上传接口
}

然后注意一下这个位置

<img :src="proxy.globaInfo.imageUrl + modelValue" alt="">

这里的globaInfo.imageUrl是在全局中进行调用,所以上方使用proxy来获取路径位置

main.js配置如下

import App from './App.vue'
const app = createApp(App);
app.config.globalProperties.globaInfo = {  // 添加可以在应用程序内的任何组件实例中访问的全局 property。属性名冲突时,组件的 property 将具有优先权。
    imageUrl:'/api/file/'  //放入图片的文件夹位置
};
import ImgUpload from '@/components/ImgUpload.vue'; //引入子组件
app.component('ImgUpload',ImgUpload) // 全局调用组件

最后在父组件中引入自组件即可

<el-form-item label="封面" class prop="cover">
  <CoverUpload v-model="formData.cover"></CoverUpload>
</el-form-item>
相关文章
|
1天前
|
JavaScript 前端开发 算法
Vue 3 和 Vue 2 的区别及优点
Vue 3 和 Vue 2 的区别及优点
|
1天前
|
存储 JavaScript 前端开发
基于 ant-design-vue 和 Vue 3 封装的功能强大的表格组件
VTable 是一个基于 ant-design-vue 和 Vue 3 的多功能表格组件,支持列自定义、排序、本地化存储、行选择等功能。它继承了 Ant-Design-Vue Table 的所有特性并加以扩展,提供开箱即用的高性能体验。示例包括基础表格、可选择表格和自定义列渲染等。
|
1月前
|
JavaScript 前端开发 UED
vue2和vue3的响应式原理有何不同?
大家好,我是V哥。本文详细对比了Vue 2与Vue 3的响应式原理:Vue 2基于`Object.defineProperty()`,适合小型项目但存在性能瓶颈;Vue 3采用`Proxy`,大幅优化初始化、更新性能及内存占用,更高效稳定。此外,我建议前端开发者关注鸿蒙趋势,2025年将是国产化替代关键期,推荐《鸿蒙 HarmonyOS 开发之路》卷1助你入行。老项目用Vue 2?不妨升级到Vue 3,提升用户体验!关注V哥爱编程,全栈开发轻松上手。
|
1月前
|
JavaScript 前端开发 算法
高效工作流:用Mermaid绘制你的专属流程图;如何在Vue3中导入mermaid绘制流程图
mermaid是一款非常优秀的基于 JavaScript 的图表绘制工具,可渲染 Markdown 启发的文本定义以动态创建和修改图表。非常适合新手学习或者做一些弱交互且自定义要求不高的图表 除了流程图以外,mermaid还支持序列图、类图、状态图、实体关系图等图表可供探索。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
1月前
|
JavaScript 前端开发 API
管理数据必备;侦听器watch用法详解,vue2与vue3中watch的变化与差异
一篇文章同时搞定Vue2和Vue3的侦听器,是不是很棒?不要忘了Vue3中多了一个可选项watchEffect噢。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
11天前
|
JavaScript
vue实现任务周期cron表达式选择组件
vue实现任务周期cron表达式选择组件
69 4
|
4月前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
216 1
|
1天前
|
缓存 JavaScript 前端开发
Vue 基础语法介绍
Vue 基础语法介绍
|
1月前
|
JavaScript 前端开发 算法
vue渲染页面的原理
vue渲染页面的原理
128 56
|
1月前
|
SQL JavaScript 前端开发
Vue实现动态数据透视表(交叉表)
Vue实现动态数据透视表(交叉表)
169 13
下一篇
oss创建bucket