获取Element UI中button组件的ID值

本文介绍如何在Vue.js应用中,特别是在使用Element UI库时,有效地获取button组件的ID值。通过绑定ID和利用Vue实例的方法,可以方便地在组件间交互和操作特定按钮。
摘要由CSDN通过智能技术生成

获取Element UI中button组件的ID值

<template>
    <div>
        <div style="display: flex;justify-content: center;">
            <div style="float:left;"><el-button @click.native="getTenCountryBarIndex($event)" id="confirmed_number_bar" autofocus=true>确诊人数</el-button></div>
            <div style="float:left;"><el-button @click.native="getTenCountryBarIndex($event)" id="existing_confirmed_number_bar">现存确诊人数</el-button></div>
        </div>
    </div>
</template>

<script>
    export default {
        name: "demo",
        data(){
            return{
                current_bar_chart,
            }
        },
        methods:{
            getTenCountryBarIndex:function(e) {
                //获取当前点击的按钮的id值
                var current_id = e.currentTarget.id;
                console.l
Element UI 的 Upload 组件是一个文件上传组件,允许用户上传多个文件,并支持拖拽上传和文件预览。下面我将详细介绍这个组件的使用方法。 ## 安装 首先,需要在项目安装 Element UI。 ```bash npm install element-ui --save ``` 然后,在 main.js 引入 Element UI。 ```javascript import Vue from 'vue' import ElementUI from 'element-ui' import 'element-ui/lib/theme-chalk/index.css' Vue.use(ElementUI) ``` ## 基本用法 在需要使用 Upload 的组件,可以这样写: ```html <el-upload class="upload-demo" action="/upload" :data="{ user_id: 123 }" :on-success="handleSuccess" :on-error="handleError" :before-upload="beforeUpload" :file-list="fileList" :auto-upload="false"> <el-button slot="trigger" size="small" type="primary">选取文件</el-button> <el-button size="small" type="success" @click="submitUpload">上传到服务器</el-button> <div slot="tip" class="el-upload__tip">只能上传jpg/png文件,且不超过500kb</div> </el-upload> ``` 上面代码,`action` 属性是上传的后端接口地址,`data` 属性是上传时需要携带的额外参数,`on-success` 和 `on-error` 属性分别是上传成功和失败时的回调函数,`before-upload` 属性是上传前的校验函数,`file-list` 属性是已经上传的文件列表,`auto-upload` 属性表示是否自动上传。 在 Upload 组件,需要通过 `slot` 分别定义两个按钮,分别是选取文件和上传到服务器的按钮。同时,可以通过 `slot` 定义提示信息。 ```html <el-button slot="trigger" size="small" type="primary">选取文件</el-button> <el-button size="small" type="success" @click="submitUpload">上传到服务器</el-button> <div slot="tip" class="el-upload__tip">只能上传jpg/png文件,且不超过500kb</div> ``` 最后,需要在 Vue 实例定义对应的函数。 ```javascript export default { data() { return { fileList: [] } }, methods: { handleSuccess(response, file, fileList) { console.log(response, file, fileList); }, handleError(error, file, fileList) { console.log(error, file, fileList); }, beforeUpload(file) { const isJPG = file.type === 'image/jpeg' || file.type === 'image/png'; const isLt2M = file.size / 1024 / 1024 < 2; if (!isJPG) { this.$message.error('上传头像图片只能是 JPG 格式!'); } if (!isLt2M) { this.$message.error('上传头像图片大小不能超过 2MB!'); } return isJPG && isLt2M; }, submitUpload() { this.$refs.upload.submit(); } } } ``` 上面代码,`handleSuccess` 和 `handleError` 分别是上传成功和失败时的回调函数,在这里可以对上传的结果进行处理。`beforeUpload` 是上传前的校验函数,可以在这里对上传的文件进行校验。`submitUpload` 用于手动触发上传。 ## 高级用法 ### 限制上传文件类型和大小 可以通过 `accept` 和 `before-upload` 属性来限制上传文件的类型和大小。 ```html <el-upload class="upload-demo" action="/upload" :data="{ user_id: 123 }" :on-success="handleSuccess" :on-error="handleError" :before-upload="beforeUpload" :file-list="fileList" :auto-upload="false" accept="image/*" :limit="3" :on-exceed="handleExceed"> <el-button slot="trigger" size="small" type="primary">选取文件</el-button> <el-button size="small" type="success" @click="submitUpload">上传到服务器</el-button> <div slot="tip" class="el-upload__tip">只能上传jpg/png文件,且不超过500kb</div> </el-upload> ``` 上面代码,`accept` 属性限制了只能上传图片类型的文件,`before-upload` 函数限制了文件大小不超过 500KB,同时还设置了最多上传 3 个文件的限制,并在超出限制时触发 `on-exceed` 方法。 ```javascript handleExceed(files, fileList) { this.$message.warning(`当前限制选择 ${this.limit} 个文件,本次选择了 ${files.length} 个文件,共选择了 ${files.length + fileList.length} 个文件`); } ``` ### 上传到阿里云 OSS 可以通过 `before-upload` 和 `custom-request` 属性来实现上传到阿里云 OSS。 ```html <el-upload class="upload-demo" :action="ossConfig.host" :data="ossConfig.params" :on-success="handleSuccess" :on-error="handleError" :before-upload="beforeUpload" :file-list="fileList" :auto-upload="false" :custom-request="ossConfig.customRequest"> <el-button slot="trigger" size="small" type="primary">选取文件</el-button> <el-button size="small" type="success" @click="submitUpload">上传到服务器</el-button> <div slot="tip" class="el-upload__tip">只能上传jpg/png文件,且不超过500kb</div> </el-upload> ``` 上面代码,`action` 属性设置为阿里云 OSS 的上传地址,`data` 属性设置为上传时需要携带的额外参数。在 `before-upload` 函数,需要返回一个 Promise 对象,该 Promise 对象需要实现上传到阿里云 OSS 的逻辑。 ```javascript beforeUpload(file) { const isJPG = file.type === 'image/jpeg' || file.type === 'image/png'; const isLt2M = file.size / 1024 / 1024 < 2; if (!isJPG) { this.$message.error('上传头像图片只能是 JPG 格式!'); } if (!isLt2M) { this.$message.error('上传头像图片大小不能超过 2MB!'); } return isJPG && isLt2M && new Promise((resolve, reject) => { const ossConfig = this.getOssConfig(); this.ossConfig = ossConfig; const client = new OSS({ accessKeyId: ossConfig.accessid, accessKeySecret: ossConfig.accesskey, stsToken: ossConfig.securitytoken, bucket: ossConfig.bucket, region: ossConfig.region, cname: true }); client.multipartUpload(ossConfig.dir + '/' + file.name, file).then((result) => { console.log(result); resolve(); }).catch((error) => { console.log(error); reject(); }); }); }, getOssConfig() { // 获取阿里云 OSS 的配置 } ``` 在 `custom-request` 函数,可以实现上传成功和失败的回调函数。 ```javascript ossConfig: { host: '', params: {}, customRequest: (config) => { const { action, data, file, headers, onError, onSuccess, onProgress } = config; const xhr = new XMLHttpRequest(); xhr.open('POST', action, true); Object.keys(headers).forEach((key) => { xhr.setRequestHeader(key, headers[key]); }); xhr.onload = function onload() { if (xhr.readyState === 4 && xhr.status === 200 && xhr.responseText !== '') { try { const response = JSON.parse(xhr.responseText); onSuccess(response, xhr); } catch (error) { onError(error, xhr); } } else { onError(new Error('上传失败'), xhr); } }; xhr.onerror = function onerror(error) { onError(error, xhr); }; xhr.upload.onprogress = function onprogress(event) { if (event.total > 0) { event.percent = (event.loaded / event.total) * 100; } onProgress(event, xhr); }; const formData = new FormData(); Object.keys(data).forEach((key) => { formData.append(key, data[key]); }); formData.append('file', file); xhr.send(formData); } }, ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值