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

文章介绍了如何在Vue.js中创建一个自定义上传图片组件,包括设置基础结构、自定义背景和图标样式,以及实现上传方法。组件使用了ElementUI的el-upload,通过http-request覆盖默认上传行为,支持单图上传,并展示了相关CSS样式和事件处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

自定义封装上传图片样式

一、首先需要新建一个自组建完善基础的结构,我这里起名为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;
  }
}

样式效果如下:
在这里插入图片描述

三、上传方法

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

请添加图片描述

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

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>
### 封装 Vue 3 中 Element Plus 的 `el-button` 组件 为了在 Vue 3 中二次封装 Element Plus 的按钮组件 (`el-button`),可以创建一个新的自定义组件来扩展其功能。这不仅有助于保持代码的整洁性和可维护性,还允许向现有组件添加额外的功能或样式。 #### 创建自定义 Button 组件 首先,在项目中安装并配置好 Element Plus 后,新建一个名为 `CustomElButton.vue` 文件用于构建自定义按钮: ```vue <template> <el-button :type="buttonType" @click="handleClick"> {{ buttonText }} </el-button> </template> <script setup> import { defineProps, toRefs } from &#39;vue&#39;; const props = defineProps({ buttonType: { type: String, default: &#39;default&#39; }, buttonText: { type: String, required: true } }); // 解构属性以便更方便地使用它们 const { buttonType, buttonText } = toRefs(props); function handleClick() { console.log(&#39;Button clicked&#39;); } </script> <style scoped> /* 可选:在此处添加特定于该组件的CSS */ </style> ``` 此部分展示了如何基于官方文档中的指导[^1] 来设计一个简单的自定义按钮组件。它接收两个参数——按钮类型(`buttonType`) 和 显示文本(`buttonText`) ,并通过监听点击事件执行指定操作。 #### 注册与使用新组件 接着,在其他地方如页面布局文件里导入刚刚制作好的 `CustomElButton` 并将其作为子组件注册进去: ```javascript import CustomElButton from &#39;@/components/CustomElButton.vue&#39;; export default { name: "App", components: { CustomElButton }, }; ``` 最后,在模板内像下面这样调用这个新的按钮组件: ```html <!-- App.vue --> <template> <!-- ... --> <custom-el-button button-type="primary" button-text="提交"></custom-el-button> <!-- ... --> </template> ``` 以上过程遵循了关于如何将第三方库集成到应用程序以及怎样利用组合 API 构建响应式界面的最佳实践[^2] 。值得注意的是,这里采用 `<script setup>` 语法糖简化了脚本编写方式,并且通过解构递给组件的数据使得逻辑更加清晰易懂。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Southern Wind

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值