成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

VUE 實現(xiàn)element upload上傳圖片到阿里云

瀏覽:184日期:2022-12-09 13:02:27

首先安裝依賴

cnpm install ali-oss

封裝client

VUE 實現(xiàn)element upload上傳圖片到阿里云

若是想減小打包后靜態(tài)資源大小,可在index.html引入:(然后在client.js里注釋掉const OSS = require(‘a(chǎn)li-oss’))

<script src='http://gosspublic.alicdn.com/aliyun-oss-sdk-4.4.4.min.js'></script>

const OSS = require(’ali-oss’)export function client(data) { // 后端提供數(shù)據(jù) return new OSS({ region: data.endpoint, // *****.aliyuncs.com accessKeyId: data.accessKeyId, accessKeySecret: data.accessKeySecret, bucket: data.bucketName, endpoint: data.endpoint, secure: true })}

然后,在vue頁面引用,給client傳入后臺返回的阿里數(shù)據(jù)

結(jié)果如下圖:

VUE 實現(xiàn)element upload上傳圖片到阿里云

1、HTML部分

<el-upload action='' :http-request='Upload' :data='Aliyun' :multiple='false' :show-file-list='true' list-type='picture-card' :on-preview='handlePictureCardPreview' :on-remove='handleRemove' :limit='5'> <i /></el-upload><el-dialog :visible.sync='dialogVisible'> <img :src='http://www.piao2010.com/bcjs/dialogImageUrl' alt=''></el-dialog><p style='color: #999;'>圖片上傳限制: 1.最多5張; 2.最大1M</p>

2、JS部分

import { getAliyun, createOrder } from ’@/api/order-management’import { client } from ’@/utils/alioss’export default { name: ’Appeal’, data() { return { dialogImageUrl: ’’, dialogVisible: false, Aliyun: {}, // 存簽名信息 progress: 0, // 進度條 imgUrl: [] // 存上傳后的圖片url } }, created() { this.getAliyun() }, methods: { // 獲取阿里云數(shù)據(jù) async getAliyun() { const { data } = await getAliyun() this.Aliyun = data }, // 上傳圖片 Upload(file) { const that = this // 判斷擴展名 const tmpcnt = file.file.name.lastIndexOf(’.’) const exname = file.file.name.substring(tmpcnt + 1) const names = [’jpg’, ’jpeg’, ’png’] if (names.indexOf(exname) < 0) { this.$message.error(’不支持的格式!’) return } if (file.size > 1024 * 1024) { this.$message.error(’圖片大小最大1M’) return } async function multipartUpload() { // const fileName = that.name + file.file.uid const fileName = that.Aliyun.objectName + +’/’ + Date.now() + ’-’ + file.file.name // fileName = aliyunConfig.objectName+’/’+Date.now()+’-’+file.name //所要上傳的文件名拼接 (test/) // 定義唯一的文件名,打印出來的uid其實就是時間戳 // client 是第一步中的 client client(that.Aliyun).put(fileName, file.file, { progress: function(p) { // 獲取進度條的值 console.log(p) that.progress = p * 100 } }).then( result => { // 下面是如果對返回結(jié)果再進行處理,根據(jù)項目需要 // console.log(result) // that.imgUrl = ’http://’ + result.bucket + ’.’ + that.Aliyun.endpoint + ’/’ + result.name that.dialogImageUrl = result.url that.imgUrl.push({ name: file.file.name, url: result.url }) console.log(that.imgUrl) }).catch(err => { console.log(’err:’, err) }) } multipartUpload() }, // 圖片預覽 handlePictureCardPreview(file) { this.dialogImageUrl = file.url this.dialogVisible = true }, // 刪除圖片 handleRemove(file, fileList) { // console.log(file) for (var i in this.imgUrl) { if (this.imgUrl[i].name === file.name) { this.imgUrl.splice(i, 1) } } } }}</script>

補充知識:vue-cli項目中,配合element_ui來實現(xiàn)上傳圖片與視頻到oss上。

<template> <div class='basicInfo'> <el-upload v-loading='fileLoading' accept='image/*' drag action='https://zxcity-app.oss-cn-hangzhou.aliyuncs.com' :show-file-list='false' :data='ossParams' :before-upload='checkParams' :on-progress='progress' :on-error='uploadErr' :on-success='uploadSuccess' :on-remove='fileListRemove' multiple > </el-upload> <div v-for='(item,index) in fileList' :key='index' class='imgDiv'> <img :src='http://www.piao2010.com/bcjs/item.imgUrl' alt=''> <p>{{item.progress}}</p> </div> </div></template><script>import axios from ’axios’export default { data () { return { form: { url: ’’ }, fileList: [], fileLoading: false, ossParams: { expireTime: ’’, key: ’’, dir: ’’ } } }, methods: { // 圖片上傳前檢測參數(shù)變化 checkParams (file) { var _this = this var promise = new Promise((resolve, reject) => { axios.get(’https://share.zxtest.izxcs.com/zxcity_restful/ws/oss/ossUpload’, {}) .then(function (response) { var params = response.data _this.ossParams = params _this.ossParams.name = file.name _this.ossParams.OSSAccessKeyId = params.accessid _this.ossParams.success_action_status = ’200’ _this.ossParams.key = params.dir + ’/’ + _this.getUUID() var obj = { name: _this.ossParams.name, key: _this.ossParams.key, host: _this.ossParams.host, progress: 0, imgUrl: ’’ } _this.fileList.push(obj) // _this.fileLoading = true resolve() }) .catch(function (error) { console.log(error, ’錯誤’) reject(error) }) }) return promise }, // 上傳中 progress (event, file, fileList) { console.log(’上傳中...’) console.log(file) console.log(fileList) this.fileList.forEach((item, index) => { if (item.name === file.name) { item.progress = parseInt(file.percentage) } }) }, // 上傳失敗提示 uploadErr (res) { this.$message.error(’上傳出錯!’) }, // 上傳成功后上傳到file表 uploadSuccess (response, file, fileList) { console.log(’上傳成功’) this.fileList.forEach((item, index) => { if (item.name === file.name) { item.imgUrl = item.host + ’/’ + item.key item.progress = 100 } }) }, // 文件刪除 fileListRemove (file, fileList) { this.form.url = ’’ }, // 隨機名稱 getUUID () { return `${this.str4()}${this.str4()}-${this.str4()}-${this.str4()}-${this.str4()}-${this.str4()}${this.str4()}${this.str4()}` }, str4 () { return (((1 + Math.random()) * 0x10000) | 0).toString(16).substring(1) } }}</script><style lang='less' scoped>.imgDiv{ display: block; float: left; width: 80px; height: 100px; border: 2px solid black; img{ display: block; width: 50px; height: 80px; } p{ font-size: 14px; text-align: center; }}</style>

以上這篇VUE 實現(xiàn)element upload上傳圖片到阿里云就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標簽: Vue
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
国产欧美一区二区三区在线老狼| 亚洲视频香蕉人妖| 亚洲天堂av一区| 久久亚洲一区二区| 暴力调教一区二区三区| 亚洲综合色视频| 欧美精品高清视频| 在线欧美一区| 国产999精品久久久久久绿帽| 中文成人av在线| 精品久久久久久久久久久久久久久久久| 国产伦精品一区| 欧美精品aa| 成人免费av在线| 男女男精品视频| 亚洲一区二区五区| 国产精品久久久久aaaa| 欧美成人精品高清在线播放| 欧美资源在线| 欧美视频四区| 91免费看`日韩一区二区| 日韩电影一区二区三区| 中文字幕一区二区不卡| 久久无码av三级| 日韩欧美123| 欧美日韩国产在线观看| 国产欧美一区二区三区另类精品 | 国产aⅴ精品一区二区三区色成熟| 亚洲香蕉伊在人在线观| 国产精品免费久久久久| 日本一区二区视频在线| 亚洲精品一区在线观看| 日韩一区二区精品| 欧美一区二区视频在线观看| 日本道精品一区二区三区| 国产深夜精品| 99亚洲伊人久久精品影院红桃| 欧美另类视频| 欧美在线亚洲综合一区| 99久久99久久久精品齐齐| 国产成人免费高清| 丁香另类激情小说| 国产成人免费xxxxxxxx| bt7086福利一区国产| 国产成人综合自拍| 成人性生交大片免费看中文网站| 国产综合久久久久影院| 国产麻豆精品久久一二三| 精品一区二区综合| 国内精品在线播放| 国产夫妻精品视频| 91麻豆高清视频| 欧美日韩精品| 亚洲激情网址| 久久av一区| 欧美男同性恋视频网站| 精品国产欧美一区二区| 国产亚洲制服色| 国产精品久久久久久久久果冻传媒 | 奶水喷射视频一区| 久久久水蜜桃| 欧美日韩高清一区二区三区| 日韩欧美成人激情| 综合网在线视频| 午夜精品久久久久久久久| 日韩精品一二区| 韩国精品久久久| 99精品欧美一区| 99亚洲一区二区| 欧美在线观看你懂的| 在线观看91精品国产麻豆| 久久综合给合久久狠狠狠97色69| 久久亚洲捆绑美女| 亚洲伦理在线精品| 免费成人在线视频观看| 国产成人免费av在线| 伊人色综合久久天天五月婷| 一本色道久久综合亚洲91| 精品国产亚洲一区二区三区在线观看| 亚洲欧洲av色图| 日韩av不卡在线观看| 成人午夜看片网址| 午夜一区二区三视频在线观看| 欧美日韩成人高清| 亚洲精品国产一区二区精华液| 热久久免费视频| 欧美日韩调教| 欧美日韩国产美女| 亚洲欧美日韩国产成人精品影院 | 在线观看视频91| 欧美激情综合五月色丁香| 偷拍自拍另类欧美| 91免费观看视频| 色婷婷亚洲精品| 国产欧美精品一区二区色综合| 久久精品国产99久久6| 亚洲午夜激情| 日韩免费视频一区| 日韩精品免费专区| 午夜精品亚洲| 欧美三电影在线| 亚洲综合在线观看视频| 91蝌蚪porny成人天涯| 在线中文字幕一区| 亚洲人成人一区二区在线观看| 国产麻豆午夜三级精品| 国产日韩亚洲欧美精品| 国产视频一区二区在线观看| 欧美96一区二区免费视频| 国内精品久久国产| 日韩情涩欧美日韩视频| 免费日韩伦理电影| 销魂美女一区二区三区视频在线| 中文字幕在线不卡视频| 成人性生交大合| 欧美性色欧美a在线播放| 亚洲国产精品视频| 亚洲欧洲日韩综合二区| 国产精品免费av| 欧美凹凸一区二区三区视频| 精品国产网站在线观看| 国产99精品国产| 欧美精品日韩一本| 国内外成人在线| 色婷婷狠狠综合| 亚洲va国产va欧美va观看| 亚洲视频导航| 日韩美女精品在线| 在线欧美亚洲| 亚洲免费成人av| 亚洲性人人天天夜夜摸| 亚洲色图丝袜美腿| 99精品国产在热久久婷婷| 亚洲欧洲性图库| 国语精品中文字幕| 中文字幕一区在线| 亚洲精品一级| 亚洲一区二区欧美激情| 亚洲麻豆一区| 亚洲国产美国国产综合一区二区| 香蕉亚洲视频| 看电视剧不卡顿的网站| 欧美久久一二三四区| 国产精品自拍三区| 欧美一级二级三级乱码| 国产a久久麻豆| 欧美精品一区二区三| 9人人澡人人爽人人精品| 国产夜色精品一区二区av| 亚洲国产欧美日韩| 婷婷一区二区三区| 91.成人天堂一区| 成人av在线影院| 国产精品美女久久久久高潮| 在线观看日韩av电影| 亚洲一二三四区不卡| 欧美综合亚洲图片综合区| 国产精品911| 久久九九国产精品| 国产欧美日韩伦理| 美女网站一区二区| 日韩欧美一区电影| 国产精品激情| 亚洲成人午夜影院| 欧美日韩一区二区电影| 成人午夜精品在线| 中文字幕一区二区三区蜜月 | 亚洲欧洲日产国码二区| 鲁大师成人一区二区三区| 青娱乐精品视频| 久久先锋影音av| 国产精品毛片| 岛国精品一区二区| 亚洲另类春色国产| 在线电影一区二区三区| 午夜亚洲福利| 国产一区二区三区在线看麻豆| 中文字幕一区av| 精品视频免费看| 欧美激情视频一区二区三区免费| 亚洲综合成人在线| 日韩欧美123| 久久精品盗摄| 91在线丨porny丨国产| 日一区二区三区| 国产精品丝袜久久久久久app| 免费永久网站黄欧美| 91在线小视频| 韩国v欧美v亚洲v日本v| 一区二区三区精品| 国产亚洲污的网站| 欧美另类久久久品| 性高湖久久久久久久久| 99久久免费视频.com| 奇米一区二区三区av| 亚洲伦在线观看| 久久久精品黄色| 91精品国产欧美一区二区18| 国产精品久久久对白| 91蜜桃在线观看|