日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

vue3.0搭配.net core實現(xiàn)文件上傳組件

瀏覽:176日期:2022-11-09 10:17:53

在開發(fā)Web應用程序中,文件上傳是經常用到的一個功能。在Jquery時代,做上傳功能,一般找jQuery插件就夠了,很少有人去探究上傳文件插件到底是怎么做的。簡單列一下我們要做的技術點和功能點

使用技術

客戶端使用vue.js 3.0,并使用vue3新增的功能:Composition API ,服務器使用asp.net core

功能點

標簽美化 文件預覽 文件上傳 服務器接收文件

文件選擇美化

在標準的html文件選擇標簽,是十分不美觀的。大概就是下圖的樣子

vue3.0搭配.net core實現(xiàn)文件上傳組件

但是我們的設計師的設計圖可不是這樣的啊,所以第一步是選擇美化一下樣式。

標簽美化

找遍整個搜索引擎,美化文件選擇標簽只有兩種方法

設置input標簽透明度為0,然后定位一個其他的容易修改樣式的標簽到透明度度為0的input標簽上。 設置input標簽的display為none,然后使用JavaScript來觸發(fā)當前input的點擊事件。

因為筆者最近在做基于vue.js 3.0的項目,需要自己自定義很多UI組件,所以參考了layui element ,它們都是使用第二種方式來美化文件選擇標簽。

vue3.0搭配.net core實現(xiàn)文件上傳組件

假設我們UI設計圖是上圖的樣式,如果需要美化,只需要隱藏文件選擇的Input標簽。然后放置一個按鈕,然后設置按鈕的樣式為設計圖上的樣式即可

<div class='uploader'> <button>選擇文件</button> <input type='file' placeholder='請選擇文件' /> </div>

.uploader { display: inline-block; button { background: #4e6ef2; color: aliceblue; padding: 5px; outline: none; border: none; &:hover { opacity: 0.8; } &:active { opacity: 1; } } input { display: none; }}

美化完成組件后,我們需要用在button點擊的時候,使用JavaScript去點擊隱藏的input標簽

<template> <div class='uploader'> <button @click='btnClick'>選擇文件</button> <input type='file' placeholder='請選擇文件' ref='fileSelector' /> </div></template> <script>import { ref } from 'vue';export default { name: 'uploader', setup() { const fileSelector = ref(null); const btnClick = () => { fileSelector.value.click(); }; return { fileSelector, btnClick, }; },};</script>

在Composition api中要獲取到標簽的ref,不能使用this.$refs來獲取。當然,你如果喜歡使用vue2的options api。那依然可以使用this.$refs來獲取標簽的el只需要簡單的觸發(fā)input的click事件,就可以使瀏覽器彈出文件選擇框了。

文件預覽

基本上所有的文件上傳組件,都有預覽上傳圖片的功能。本文所寫的上傳組件當然也不例外。監(jiān)聽input標簽的change事件,獲取到files對象。然后使用FileReader讀取文件信息。

const fileChange = (e) => { let files = e.target.files; console.log(files); for (let i = 0; i < files.length; i++) { let file = files[i]; var fileReader = new FileReader(); fileReader.addEventListener( 'load', (event) => { console.log(event); data.imgList.push({ base64: event.target.result, }); }, false ); fileReader.readAsDataURL(file); } };

vue3.0搭配.net core實現(xiàn)文件上傳組件

在Chromium內核等高版本瀏覽器中,無法像低版本瀏覽器一樣,能獲得文件的具體磁盤路徑。如果像以前用文件路徑去獲取文件。只能獲得一個 C:fakepath'+文件名的路徑。無法獲取到真實文件路徑。據說可以通過某些方法獲取真實路徑。我試過,沒成功。有興趣的朋友可以試試。

文件上傳

選擇文件后,我們需要把文件保存到到服務器。在傳統(tǒng)的多頁面web程序中,只需要設置按鈕的type為submit,然后使用form表單直接提交文件和表單信息到服務器去。但是我們做單頁面程序,一般來說是通過JavaScript的ajax去上傳文件。

const uploadServer = (file) => { var form = new FormData(); form.append('file', file); var xhr = new XMLHttpRequest(); xhr.open('post', props.server); xhr.onreadystatechange = () => { if (xhr.readyState == 4 && xhr.status == 200) { var res = JSON.parse(xhr.responseText); console.log('上傳成功'); data.logs.push({ log: res, }); } }; xhr.upload.onprogress = (event) => { if (event.lengthComputable) { var percent = (event.loaded / event.total) * 100; console.log('上傳進度:' + percent); } }; xhr.onerror = () => { console.log('上傳文件錯誤'); }; xhr.ontimeout = () => { console.log('上傳超時'); }; xhr.send(form); };

在頁面上新增一個按鈕,用來手動觸發(fā)上傳

<div class='uploader'> <button @click='btnClick'>選擇文件</button> <button @click='uploadClick'>立即上傳</button> <input type='file' placeholder='請選擇文件' ref='fileSelector' @change='fileChange' multiple /> <div class='image-list'> <img v-for='(item, i) in data.imgList' :key='i' :src='http://www.b3g6.com/bcjs/item.base64' /> </div> <div class='log'> <p v-for='(item, i) in data.logs' :key='i'>{{ item.log }}</p> </div> </div>

點擊 立即上傳 按鈕,觸發(fā)上傳

const uploadClick = () => { data.files.forEach((file) => { uploadServer(file); }); };

vue3.0搭配.net core實現(xiàn)文件上傳組件

服務器接收

在服務器編程中,我們使用C#來接收上傳的文件。

/// <summary> /// 上傳 /// </summary> /// <param name='files'></param> /// <returns></returns> [HttpPost('/upload')] public async Task<IActionResult> Upload([FromServices] IWebHostEnvironment host) { var files = Request.Form.Files; long size = files.Sum(f => f.Length); List<string> list = new List<string>(); foreach (var formFile in files) {if (formFile.Length > 0){ var path = Path.Combine(host.WebRootPath, 'files'); if (!Directory.Exists(path)) { Directory.CreateDirectory(path); } string fileName = $'{Guid.NewGuid():N}{Path.GetExtension(formFile.FileName)}'; path = Path.Combine(path, fileName); var filePath = path; using var stream = System.IO.File.Create(filePath); await formFile.CopyToAsync(stream); var c = Path.VolumeSeparatorChar; list.Add($'{Request.Scheme}://{Request.Host.Value}/{Path.Combine('files', fileName).Replace(Path.DirectorySeparatorChar, Path.AltDirectorySeparatorChar)}');} } return Ok(new { list = list, size }); }

使用dotnet run運行asp.net core服務端。然后點擊上傳,你以為就上傳成功了嗎?不!沒那么簡單。如果如果vue程序和asp.net core程序,不在同一個域名下,你還得處理上傳跨域問題。當然這個問題在asp.net core中是非常簡單的。只需要簡單配置一下即可

如果在IIS或者Nginx下,就需要修改對應站點的配置文件了。當然具體服務器軟件的配置不在本篇文章的討論之下。有需要的同學可以私下交流asp.net core跨域處理

app.UseCors(options => {options.WithOrigins('http://localhost:3000', 'http://127.0.0.1', 'http://localhost:8080'); // 允許特定ip跨域options.AllowAnyHeader();options.AllowAnyMethod();options.AllowCredentials(); });

以上配置必須要放在app.UseStaticFiles();之前才會生效。

上傳成功后,你就會在服務器的wwwroot的files文件夾中看到上傳的圖片文件了。

vue3.0搭配.net core實現(xiàn)文件上傳組件

本文完成了基本的功能,起一個拋磚引玉的作用。更多功能,如:文件類型限制,文件大小限制等,可以根據使用場景自定義擴展

本篇vue 3.0文件上傳組件開發(fā)到這里就結束了。

以上就是vue3.0搭配.net core實現(xiàn)文件上傳組件的詳細內容,更多關于vue3.0 文件上傳的資料請關注好吧啦網其它相關文章!

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲高清成人| 国产亚洲一卡2卡3卡4卡新区| 欧美黄页在线免费观看| 久久国产免费看| 69堂免费精品视频在线播放| 欧美日韩1区2区3区| 最新亚洲国产| 一级成人国产| 日韩精品欧美成人高清一区二区| 日韩一区网站| 国产亚洲欧美日韩在线观看一区二区| 国产日韩欧美中文在线| 卡一卡二国产精品| 日本蜜桃在线观看视频| 日本久久成人网| 欧美日韩三区| 亚洲1区在线观看| 欧美日韩91| 福利一区视频| 亚洲午夜一级| 美女精品在线观看| 亚洲日产av中文字幕| 青青草精品视频| 精品72久久久久中文字幕| 天堂av在线| 亚洲一区中文| 青青草伊人久久| 精品国产亚洲一区二区三区| 91精品一区二区三区综合| 在线 亚洲欧美在线综合一区| 日韩专区在线视频| 日韩免费精品| 成人一区不卡| 好看不卡的中文字幕| 视频一区日韩精品| 精品三区视频| 亚洲在线观看| 911精品国产| 日韩一区二区中文| 三级欧美在线一区| 捆绑调教美女网站视频一区| 亚洲天堂成人| 日韩一区二区三区免费视频| 精品在线网站观看| 欧美va亚洲va日韩∨a综合色| 婷婷综合福利| 在线人成日本视频| 乱人伦精品视频在线观看| 国产精品毛片aⅴ一区二区三区| 成人羞羞视频播放网站| 婷婷综合成人| 欧美中文一区二区| 蜜桃视频一区二区三区在线观看| 国产精品久久久久久久久久齐齐 | 久久精品影视| 亚洲精品看片| 欧美天堂视频| 欧美在线不卡| 亚洲激情婷婷| 精品三级国产| 亚洲深夜福利在线观看| 四虎国产精品免费观看| 亚洲伊人精品酒店| 色婷婷久久久| 美女高潮久久久| 日韩一区欧美二区| 国产超碰精品| 国产精品久久久久77777丨| 91久久久精品国产| 国产精品极品在线观看| 国产精品腿扒开做爽爽爽挤奶网站| 久久这里只有精品一区二区| 在线亚洲成人| 91看片一区| 国产福利一区二区三区在线播放| 欧美理论视频| 岛国av免费在线观看| 日韩区欧美区| 久久国产99| 在线成人动漫av| 日韩成人精品一区| 国产精品毛片久久久| 中文字幕亚洲在线观看| 欧美手机在线| 日韩亚洲一区在线| 麻豆高清免费国产一区| 欧美一级一区| 亚洲另类视频| 99riav国产精品| 精品成人免费一区二区在线播放| 国产免费av国片精品草莓男男| 中文字幕一区二区av| 免费视频一区三区| 中文在线а√在线8| 免费一级欧美片在线观看网站| 亚洲1区在线观看| 奶水喷射视频一区| 一级欧洲+日本+国产| 日韩精品午夜| 成人在线网站| 中文字幕高清在线播放| 国产精品国产三级在线观看| 亚洲18在线| 亚洲精品美女91| 亚洲小说春色综合另类电影| 亚洲欧洲另类| 亚洲激情黄色| 国产视频一区三区| 国产一区久久| 亚洲一本视频| 欧美日韩在线播放视频| 99精品国产一区二区三区| 亚洲三级欧美| 亚洲免费福利| 91精品婷婷色在线观看| 久久激情中文| 99久久99视频只有精品| 日韩欧美一区免费| 午夜久久中文| 久久久久久免费视频| 久久久久久网| 四虎国产精品免费观看| 日韩毛片视频| 韩日一区二区三区| 性一交一乱一区二区洋洋av| 美女精品一区| 日韩欧美另类中文字幕| 国产私拍福利精品视频二区| 国产精品毛片视频| 久久伊人国产| 午夜久久中文| 五月天久久777| 日韩精品一二区| 综合亚洲自拍| 国产精品红桃| 精品视频在线你懂得| 麻豆网站免费在线观看| 999精品一区| 日韩在线卡一卡二| 日韩av影院| 精品欧美日韩精品| 久久国产电影| 视频一区二区不卡| 国产欧美日韩视频在线| 国产一区二区三区久久 | 91精品国产成人观看| 日韩一区二区免费看| 亚洲深夜福利在线观看| 日韩精品成人| 精品久久电影| 欧美日韩国产探花| 日韩一区网站| 精品资源在线| 五月天综合网站| 日本a级不卡| 首页国产精品| 国产午夜久久| 国产精品最新| 久久婷婷丁香| 亚洲18在线| 中文字幕高清在线播放| 亚洲中午字幕| 美女性感视频久久| 成人羞羞在线观看网站| 在线看片日韩| 国产不卡一区| 免播放器亚洲| 欧美国产不卡| 国产韩日影视精品| 国产日产精品_国产精品毛片| 日韩在线不卡| 亚洲一区二区三区中文字幕在线观看 | 伊人久久大香线蕉av不卡| 精品在线99| 欧美日韩中出| 日韩欧美二区| 国产精品日本| 欧美激情在线精品一区二区三区| 久久香蕉国产| 久久国产精品免费一区二区三区| 免费看av不卡| 日韩不卡一区二区三区| 久久精品国语| 国产精品久久久网站| 99视频精品免费观看| 国产激情精品一区二区三区| 伊人成人网在线看| 另类综合日韩欧美亚洲| 美女精品在线| 天堂√中文最新版在线| 一区二区三区国产盗摄| 精精国产xxxx视频在线野外| 日韩av中文字幕一区| 亚洲一级网站| 精品在线网站观看| 中文字幕免费一区二区| 久久久久欧美精品| 欧美激情麻豆| 少妇精品在线| 狠狠色综合网|