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

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

.Net6.0+Vue3實現數據簡易導入功能全過程

瀏覽:352日期:2022-06-08 11:26:27
目錄
  • 前言
  • 1. 前端上傳文件到后臺進行數據存儲
    • 1.1編寫文件上傳接口
    • 1.2存儲上傳文件路徑,讀取數據并進行存儲
    • 1.3前端Vue建立創建列表數據頁面,包含表格功能及分頁功能
    • 1.4調用接口獲取表格數據方法
  • 1.5后臺開發數據返回接口
    • 1.6主頁面創建上傳文件組件并進行引用
    • 1.7FleUpload頁面主要上傳文件到服務器,并回調父頁面存儲接口
    • 1.8這里的title,accept參數由父頁面傳值過來,可以進行組件復用
    • 1.9提交保存時回調父頁面存儲數據方法
    • 1.10父頁面方法調用接口進行數據存儲,存儲成功后關閉子頁面
    • 1.11后臺數據存儲接口
  • 2前端讀取數據,發送讀取數據到后臺進行數據存儲
    • 2.1創建上傳數據組件并引用
    • 2.2DataUpload頁面主要讀取選擇文件數據,并進行展示
    • 2.3文件上傳成功方法,保存數據到臨時變量進行分頁處理
    • 2.4數據綁定到表格上,這里需要通過當前選擇頁碼及頁面顯示數量處理需要綁定到表格上的數據
    • 2.5點擊確認導入按鈕回調父頁面方法進行數據保存
    • 2.6父頁面方法調用接口進行數據存儲,存儲成功后關閉子頁面
    • 2.7后臺數據存儲接口
  • 總結

    前言

    在開發的過程中,上傳文件或者導入數據是一件很常見的事情,導入數據可以有兩種方式:

    • 前端上傳文件到后臺,后臺讀取文件內容,進行驗證再進行存儲
    • 前端讀取數據,進行數據驗證,然后發送數據到后臺進行存儲

    這兩種方式需要根據不同的業務才進行采用

    這次用.Net6.0+Vue3來實現一個數據導入的功能

    接下來分別用代碼來實現這兩種方式

    1. 前端上傳文件到后臺進行數據存儲

    1.1編寫文件上傳接口

    [DisableRequestSizeLimit][HttpPost]public IActionResult Upload(){    var files = Request.Form.Files;    long size = files.Sum(f => f.Length);    string contentRootPath = AppContext.BaseDirectory;    List<string> filenames = new List<string>();    foreach (IFormFile formFile in files)    {if (formFile.Length > 0){    string fileExt = Path.GetExtension(formFile.FileName);    long fileSize = formFile.Length;    string newFileName = System.Guid.NewGuid().ToString() + fileExt;    var filePath = contentRootPath + "/fileUpload/";    if (!Directory.Exists(filePath))    {Directory.CreateDirectory(filePath);    }    using (var stream = new FileStream(filePath + newFileName, FileMode.Create))    {formFile.CopyTo(stream);    }    filenames.Add(newFileName);}    }    return Ok(filenames);}

    這里只是上傳文件分了兩步走,第一步把文件上傳到服務器,第二步調用接口把返回的文件路徑發送給后臺進行數據保存

    1.2存儲上傳文件路徑,讀取數據并進行存儲

    /// <summary>/// 上傳文件數據/// </summary>/// <param name="uploadStuInfoInput"></param>/// <returns></returns>[HttpPut]public IActionResult Put(DataInput uploadStuInfoInput){    Encoding.RegisterProvider(CodePagesEncodingProvider.Instance);    var filePath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "fileUpload", uploadStuInfoInput.filePath);    if (!System.IO.File.Exists(filePath))    {return BadRequest("導入失敗,文件不存在!");    }    var row = MiniExcelLibs.MiniExcel.Query<CompanyImportInput>(filePath).ToList();    companies.AddRange(row.Select(x => new Company { Name = x.名稱, Address = x.地址 }));    return Ok("導入成功!");}

    1.3前端Vue建立創建列表數據頁面,包含表格功能及分頁功能

    <el-table :data="state.tableData.data">? ? ? <el-table-column v-for="item in state.colunm" :prop="item.key" :key="item.key" :label="item.lable">? ? ? </el-table-column>? ? </el-table>?<div class="block flex justify-end" v-if="state.tableData.total > 0">? ? ? <el-pagination v-model:currentPage="state.searchInput.PageIndex" v-model:page-size="state.searchInput.PageSize"? ? ? ? :page-sizes="[10, 50, 200, 1000]" layout="total, sizes, prev, pager, next, jumper" @size-change="getData"? ? ? ? @current-change="getData" :total="state.tableData.total" />? ? </div>

    1.4調用接口獲取表格數據方法

    const getData = () => {? ? ? axios.get("/Company", { params: state.searchInput }).then(function (response) {? ? ? ? state.tableData = response.data;? ? ? })? ? }

    1.5后臺開發數據返回接口

    [HttpGet]public dynamic Get([FromQuery] SelectInput selectInput){    return new    {total = companies.Count(),data = companies.Skip((selectInput.pageIndex - 1) * selectInput.pageSize).Take(selectInput.pageSize).ToList()    };}

    1.6主頁面創建上傳文件組件并進行引用

    import FileUpload from "@/components/FileUpload.vue";

    并綁定子頁面回調方法fileUploadchildClick

    <FileUpload ref="fileUpload" @childClick="fileUploadchildClick" accept=".xlsx" title="上傳文件"></FileUpload>

    1.7FleUpload頁面主要上傳文件到服務器,并回調父頁面存儲接口

    <el-dialog :close-on-click-modal="false" v-model="state.dialogVisible" :title="title" width="40%">? ? <el-form :model="state.formData" label-width="130px" class="dialogForm">? ? ? <el-upload class="upload-demo" :limit="1" drag :accept="accept" :file-list="state.fileList" :show-file-list="true"? ? ? ? :on-success="fileUploadEnd" :action="fileUploadUrl()">? ? ? ? <i class="el-icon-upload"></i>? ? ? ? <div class="el-upload__text">將文件拖到此處,或<em>點擊上傳</em></div>? ? ? ? <div class="el-upload__tip">請選擇({{ ?accept ?}})文件</div>? ? ? </el-upload>? ? ? <div>? ? ? ? <el-form-item>? ? ? ? ? <el-button type="primary" @click="submit">導入</el-button>? ? ? ? ? <el-button @click="cancel">取消</el-button>? ? ? ? </el-form-item>? ? ? </div>? ? </el-form>? </el-dialog>

    1.8這里的title,accept參數由父頁面傳值過來,可以進行組件復用

    選擇文件成功回調方法

    const fileUploadEnd = (response, file) => {? ? ? state.fileresponse = file.name;? ? ? state.formData.filePath = response[0];? ? ? if (state.fileList.length > 0) {? ? ? ? state.fileList.splice(0, 1);? ? ? }? ? }

    1.9提交保存時回調父頁面存儲數據方法

    const submit = () => {? ? ? if (state.formData.filePath == "") {? ? ? ? ElMessage.error("請選擇上傳的文件")? ? ? ? return;? ? ? }? ? ? context.emit("childClick", state.formData)? ? }

    1.10父頁面方法調用接口進行數據存儲,存儲成功后關閉子頁面

    const fileUploadchildClick = (e) => {? ? ? axios.put("/Company", {? ? ? ? filePath: e.filePath,? ? ? }).then(function (response) {? ? ? ? if (response.status == 200) {? ? ? ? ? ElMessage.success(response.data);? ? ? ? ? fileUpload.value.cancel();? ? ? ? ? getData();? ? ? ? } else {? ? ? ? ? ElMessage.error(response.data)? ? ? ? }? ? ? })? ? }

    1.11后臺數據存儲接口

    /// <summary>/// 上傳文件數據/// </summary>/// <param name="uploadStuInfoInput"></param>/// <returns></returns>[HttpPut]public IActionResult Put(DataInput uploadStuInfoInput){    Encoding.RegisterProvider(CodePagesEncodingProvider.Instance);    var filePath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "fileUpload", uploadStuInfoInput.filePath);    if (!System.IO.File.Exists(filePath))    {return BadRequest("導入失敗,文件不存在!");    }    var row = MiniExcelLibs.MiniExcel.Query<CompanyImportInput>(filePath).ToList();    companies.AddRange(row.Select(x => new Company { Name = x.名稱, Address = x.地址 }));    return Ok("導入成功!");     }

    2前端讀取數據,發送讀取數據到后臺進行數據存儲

    2.1創建上傳數據組件并引用

    import DataUpload from "@/components/DataUpload.vue";

    并綁定子頁面回調方法dataUploadchildClick

    <DataUpload ref="dataUpload" @childClick="dataUploadchildClick" accept=".xlsx" title="上傳數據"></DataUpload>

    2.2DataUpload頁面主要讀取選擇文件數據,并進行展示

    <el-dialog :close-on-click-modal="false" v-model="state.dialogVisible" :title="title" width="50%">? ? <el-upload :action="accept" drag :auto-upload="false" :on-change="uploadChange" :limit="1">? ? ? <i></i>? ? ? <div>將文件拖到此處,或<em>點擊上傳</em></div>? ? </el-upload>? ? <div>? ? ? <el-form-item>? ? ? ? <el-button @click="submit">確認導入</el-button>? ? ? </el-form-item>? ? </div>? ? <el-table :data="state.tableData.data">? ? ? <el-table-column v-for="item in state.colunm" :prop="item.key" :key="item.key" :label="item.lable">? ? ? </el-table-column>? ? </el-table>? ? <div class="block flex justify-end" v-if="state.tableData.total > 0">? ? ? <el-pagination v-model:currentPage="state.searchInput.PageIndex" v-model:page-size="state.searchInput.PageSize"? ? ? ? :page-sizes="[10, 50, 200, 1000]" layout="total, sizes, prev, pager, next, jumper" @size-change="getData"? ? ? ? @current-change="getData" :total="state.tableData.total" />? ? </div>? </el-dialog>

    2.3文件上傳成功方法,保存數據到臨時變量進行分頁處理

    const uploadChange = async (file) => {? ? ? let dataBinary = await readFile(file.raw)? ? ? let workBook = XLSX.read(dataBinary, { type: "binary", cellDates: true })? ? ? let workSheet = workBook.Sheets[workBook.SheetNames[0]]? ? ? let data: any = XLSX.utils.sheet_to_json(workSheet)? ? ? let tHeader = state.colunm.map(obj => obj.lable)? ? ? let filterVal = state.colunm.map(obj => obj.key)? ? ? tHeader.map(val => filterVal.map(obj => val[obj]))? ? ? const tempData: any = [];? ? ? data.forEach((value) => {? ? ? ? const ob = {};? ? ? ? tHeader.forEach((item, index) => {? ? ? ? ? ob[filterVal[index]] = value[item].toString();? ? ? ? })? ? ? ? tempData.push(ob);? ? ? })? ? ? state.tempTableData = tempData;? ? ? getData();? ? }

    2.4數據綁定到表格上,這里需要通過當前選擇頁碼及頁面顯示數量處理需要綁定到表格上的數據

    const getData = () => {? ? ? const tempData: any = [];? ? ? state.tempTableData.forEach((value, index) => {? ? ? ? if (index >= ((state.searchInput.PageIndex - 1) * state.searchInput.PageSize) && index < ((state.searchInput.PageIndex) * state.searchInput.PageSize)) {? ? ? ? ? tempData.push(value);? ? ? ? }? ? ? });? ? ? state.tableData.data = tempData;? ? ? state.tableData.total = state.tempTableData.length;? ? }

    2.5點擊確認導入按鈕回調父頁面方法進行數據保存

    const submit = () => {? ? ? context.emit("childClick", state.tempTableData)? ? }

    2.6父頁面方法調用接口進行數據存儲,存儲成功后關閉子頁面

    const dataUploadchildClick = (data) => {? ? ? axios.post("/Company", data)? ? ? ? .then(function (response) {? ? ? ? ? if (response.status == 200) {? ? ? ? ? ? ElMessage.success(response.data);? ? ? ? ? ? dataUpload.value.cancel();? ? ? ? ? ? getData();? ? ? ? ? } else {? ? ? ? ? ? ElMessage.error(response.data)? ? ? ? ? }? ? ? ? })? ? }

    2.7后臺數據存儲接口

    /// 上傳數據/// </summary>/// <param name="uploadStuInfoInput"></param>/// <returns></returns>[HttpPost]public IActionResult Post(List<Company>  companiesInput){    companies.AddRange(companiesInput);    return Ok("保存成功!");}

    最后關于這個數據導入的功能就完成了,代碼中有很多得偽代碼,而且很多功能還待完善,后續再進行補充

    附上git地址:https://gitee.com/wyf854861085/file-upload.git

    Git演示圖:

    總結

    到此這篇關于.Net6.0+Vue3實現數據簡易導入功能的文章就介紹到這了,更多相關.Net Vue3數據導入功能內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

    標簽: ASP.NET
    成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
    亚洲国产日韩精品| 国产视频精品网| 中文字幕中文在线不卡住| 国产精品电影一区二区| 国产精品一二三四五| av成人老司机| 亚洲成人在线视频网站| 午夜亚洲影视| 91精品久久久久久久99蜜桃| 国产亚洲欧美在线| 亚洲三级免费观看| 日韩制服丝袜先锋影音| 国产不卡视频在线播放| 亚洲成人自拍视频| 中文字幕不卡一区| 亚洲18色成人| 国产精品亚洲综合一区在线观看| 久久蜜桃精品| 欧美变态tickling挠脚心| 亚洲裸体xxx| 一区二区三区鲁丝不卡| 国产一区二区三区不卡在线观看 | 亚洲高清久久| 中文字幕电影一区| 国内精品视频在线播放| 欧美在线免费播放| 久久久精品影视| 五月激情六月综合| 欧美aⅴ99久久黑人专区| 欧美专区一区二区三区| 亚洲国产综合91精品麻豆| 免费亚洲婷婷| 亚洲高清免费观看| 久久久精品五月天| 日本大胆欧美人术艺术动态| 欧美日韩爆操| 91麻豆精品国产自产在线观看一区 | 久久精品一区| 久久综合av免费| 日韩av电影免费观看高清完整版 | 国产日产欧美一区二区三区| 三级在线观看一区二区| 91福利视频在线| 亚洲蜜臀av乱码久久精品| 亚洲国产午夜| 26uuu精品一区二区三区四区在线| 成人av免费观看| 色综合久久88色综合天天免费| 国产区在线观看成人精品| 欧美黄在线观看| 国产婷婷色一区二区三区四区| 欧美日韩p片| 亚洲人亚洲人成电影网站色| 国产亚洲毛片| 免费一级片91| 亚洲国产日韩在线| 亚洲综合成人在线视频| 欧美精品一区二区三区久久久竹菊| 最好看的中文字幕久久| 亚洲欧美日韩综合国产aⅴ| 蜜桃一区二区三区在线观看| 亚洲精品一区二区三| 久久午夜免费电影| 欧美激情一区| 亚洲乱码国产乱码精品精的特点| 日本电影亚洲天堂一区| 国产**成人网毛片九色 | 在线看日本不卡| 福利一区二区在线| 国产精品天天看| 国产精品一二三区在线| 国产精品丝袜一区| 久久精品一区| 国产精一区二区三区| 久久精品夜色噜噜亚洲aⅴ| 99热这里只有成人精品国产| 日本欧美一区二区三区乱码| 欧美日韩视频专区在线播放| 亚洲国产精品久久久久秋霞影院| 欧美无乱码久久久免费午夜一区| 亚洲一区二区成人在线观看| 欧美性色黄大片| 91免费观看在线| 日韩一卡二卡三卡国产欧美| 日韩av一区二区三区四区| 91精品福利在线一区二区三区| 精品亚洲成a人| 色婷婷亚洲精品| 成人av午夜电影| 亚洲最大成人网4388xx| 欧美电影在哪看比较好| 韩国av一区二区三区在线观看| 久久综合影视| av不卡在线观看| 亚洲综合成人网| 精品少妇一区二区三区免费观看 | 国产精品区免费视频| 国产成人99久久亚洲综合精品| 亚洲色图制服丝袜| 欧美乱熟臀69xxxxxx| 欧美激情一区| 九色综合狠狠综合久久| 亚洲欧美在线高清| 亚洲九九精品| 国产一区二区在线视频| 中文字幕日韩av资源站| 91精品国产综合久久国产大片| 亚洲精品乱码久久久久久蜜桃麻豆 | 久久久影视传媒| 美女尤物久久精品| 粉嫩高潮美女一区二区三区 | 日韩欧美中文字幕制服| 国产日韩欧美一区二区三区在线观看 | 色中色一区二区| 牛人盗摄一区二区三区视频| 日韩精品成人一区二区在线| 久久久99久久| 在线日韩国产精品| 亚洲欧洲精品一区二区| 成人深夜在线观看| 久久久天堂av| 色94色欧美sute亚洲线路一ni| 欧美日韩一卡| 亚洲影院久久精品| 久久蜜桃一区二区| 欧美日韩一区三区四区| 西西人体一区二区| 欧美午夜电影在线观看| 成人性色生活片| 日韩成人一区二区三区在线观看| 国产精品美日韩| 欧美r级在线观看| 欧美在线999| 夜夜夜久久久| 全国精品久久少妇| 亚洲天堂网中文字| 337p日本欧洲亚洲大胆精品| 欧美又粗又大又爽| 国产视频一区三区| 欧美日韩国产在线一区| 国产999精品久久久久久| 蜜桃传媒麻豆第一区在线观看| 亚洲综合成人在线视频| 亚洲欧美综合色| 久久久久国产精品人| 欧美三级电影在线观看| 久久精彩视频| 亚洲人www| 91蜜桃网址入口| 成人性生交大合| 激情综合亚洲精品| 日韩av中文字幕一区二区| 一区二区三区四区视频精品免费 | 亚洲欧洲综合另类| 国产女人水真多18毛片18精品视频 | 国产精品亚洲第一区在线暖暖韩国| 日本最新不卡在线| 亚洲成人免费影院| 一区二区三区在线看| 亚洲美女视频在线| 亚洲色欲色欲www在线观看| 久久女同精品一区二区| 欧美成人精精品一区二区频| 欧美精品久久天天躁| 欧美日本一区二区| 亚洲视频一二| 久色婷婷小香蕉久久| 久久久亚洲高清| 精品美女在线播放| 91精品国产乱码久久蜜臀| 日本高清不卡在线观看| 色婷婷亚洲综合| 91黄色免费网站| 色欧美乱欧美15图片| 一本大道av伊人久久综合| 久久电影一区| 国产精品视频福利| 中文一区在线| 亚洲欧洲三级| 亚洲天堂偷拍| 国产一区二区三区四区hd| 午夜亚洲福利| 欧美日韩免费观看一区| 欧美日韩视频在线一区二区观看视频| 99久久免费精品高清特色大片| 亚洲成人免费av| 午夜亚洲福利老司机| 午夜a成v人精品| 日韩精品每日更新| 青青草成人在线观看| 美腿丝袜在线亚洲一区| 欧美aaaaa成人免费观看视频| 日韩av一区二| 久久99精品久久久| 国产精品一区三区| 国产精品1区2区3区在线观看| 国产电影一区在线| 五月天精品一区二区三区| 午夜精品视频在线观看| 日韩高清欧美激情|