layui上傳文件與資料表格的一些問題
layui是一款我比较喜欢的框架,它的界面风格和颜色搭配都是让人比较舒服的,所以我非常喜欢使用layui。
接下来就是在工作中使用layui遇到了一些比较细节的问题:
第一:layui上传文件的问题,
第二:layui 表格的问题。
首先第一个问题,就是layui上传文件的问题,首先我们来看layui是如何上传文件的:
function UpdateFile() { layui.use('upload', function () { var upload = layui.upload; //执行实例 var uploadInst = upload.render({ elem: '#upload' //绑定元素 , url: '/ExcelTemplate'//上传接口 , method: 'POST' , type: "file" , accept: 'file' , before: function (obj) { layer.load(); //上传loading } , done: function (res) { //上传完毕回调 if (res) { layer.closeAll('loading'); var d = dialog({ title: '提示', content: '上传模板成功', width: 200, ok: function () { self.location.reload(); }, }); d.show(); } else { layer.closeAll('loading'); var d = dialog({ title: '提示', content: '上传模板失败', width: 200, ok: function () { }, }); d.show(); } } , error: function () { layer.closeAll('loading'); } }); }); }
当然你需要在你的页面上定义一个按钮,然后触发点击事件,elem: '#upload' 就是用来与你的上传按钮做绑定了,接下来就是文件类型还有用post来传输。
然后我们需要在后台用一个参数去接收文件。
[HttpPost("")] public IActionResult UploadTemplate(IFormFile file) { long dateTime = DateTime.Now.ToFileTimeUtc(); string[] template = file.FileName.Split(new char[] { '\\' }, StringSplitOptions.RemoveEmptyEntries); string fileName = Path.Combine(hostingEnvironment.WebRootPath, "Upload", "ExcelTemplate", dateTime + "_" + template[template.Length - 1]); if (System.IO.File.Exists(fileName)) { System.IO.File.Delete(fileName); } try { using (FileStream fs = new FileStream(fileName, FileMode.Create)) { file.CopyTo(fs); fs.Flush(); return Ok(true); } } catch (Exception) { return BadRequest("上传模板失败!"); } }
这里是用IFormFile 去接收文件,参数名最好是file,然后对文件进行操作,那么上传的文件要怎么才能下载呢,如下:
<script type="text/html" id="down"> <a href="~/Upload/ExcelTemplate/{{d.name}}" download="{{d.name}}" class="layui-table-link">下载</a> </script>
在表格中显示和下载。
第二就是表格的问题了:
layui.use(['table', 'laypage'], function () { var laypage = layui.laypage; var table = layui.table, form = layui.form; table.render({ elem: '#PaymentDayList' , url: '/PaymentDay' , method: "get" , height: "auto" , width: "auto" , cellMinWidth: 80 , limit: 10 , curr: 1 , request: { pageName: 'pageIndex' } , page: { layout: ['limit', 'count', 'prev', 'page', 'next', 'skip'] //自定义分页布局 , groups: 5 //只显示 1 个连续页码 , first: false //不显示首页 , last: false //不显示尾页 } , limits: [10, 20, 50, 100, 500, 1000] , cols: [[ { type: "checkbox", fixed: "left" }, { type: 'numbers', title: '序号' }, { field: 'name', title: '账期名称', sort: true, width: 200 }, { field: 'settleMentInterval', title: '结算周期', sort: true, width: 100 }, { field: 'startTime', title: '账期起始时间', sort: true, width: 150 }, { field: 'endTime', title: '账期终止时间', sort: true, width: 150 }, { field: 'warnDay', title: '到期提醒日', sort: true, width: 150 }, { field: 'userName', title: '商保专员', sort: false, width: 100 }, { field: 'addTime', title: '创建时间', sort: true, width: 200 }, { field: 'isEnabled', title: '启用', templet: '#checkboxTpl', width: 100 }, { field: 'status', title: '状态', sort: false, width: 100 }, { field: 'scope', title: '适用范围', sort: false, width: 100 }, ]] }); $('#Select').on('click', function () { table.reload("PaymentDayList", { page: { curr: 1 } , where: { name: $("#name").val(), startTime: $("#startTime").val(), endTime: $("#endTime").val(), status: $("#type option:selected").val() } }); }); form.on('checkbox(lockDemo)', function (obj) { var isEnable; obj.elem.checked == true ? isEnable = "启用" : isEnable = "未启用"; $.ajax({ url: '/PaymentDay/Enabled/' + obj.value + "/" + isEnable, type: 'get', success: function (result) { if (result.code == 200) { } else { var d = dialog({ title: '提示', content: '操作失败!', ok: function () { }, }); d.show(); } } }); }); });
这时候有人可能留意到了有一个启用的checkbox,其中点击checkbox会发送get请求到控制器。从而完成与后台的交互。那么如果我们想要点击了checkbox按钮之后,我们选中这一条数据的时候不能删除这条数据怎么办呢?
我们就需要遍历一下这个页面的所有checkbox了,如下:
var table = layui.table; var checkStatus = table.checkStatus('PaymentDayList'), data = checkStatus.data; if (data.length == 1) { var check = document.getElementsByName("lock"); for (i = 0; i < check.length; i++) { if (check[i].value == data[0].id) { if (check[i].checked) { var d = dialog({ title: '提示', content: "启用了的账期不能修改", okValue: '确定', ok: function () { } }).width(200); d.show(); return; } } }
这样就可以确定哪个是选中的了。
更多layui知识请关注layui使用教程栏目。
以上是layui上傳文件與資料表格的一些問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

layui 登入頁面跳轉設定步驟:新增跳轉代碼:在登入表單提交按鈕點選事件中新增判斷,成功登入後透過 window.location.href 跳到指定頁面。修改 form 配置:在 lay-filter="login" 的 form 元素中新增 hidden 輸入字段,name 為 "redirect",value 為目標頁面位址。

layui 提供了多種取得表單資料的方法,包括直接取得表單所有欄位資料、取得單一表單元素值、使用formAPI.getVal() 方法取得指定欄位值、將表單資料序列化並作為AJAX 請求參數,以及監聽表單提交事件獲取資料。

layui與Vue的差異主要體現在功能和關注點上。 layui專注於快速開發UI元素,提供預製元件簡化頁面建置;而Vue則是全端框架,注重資料綁定、元件化開發和狀態管理,更適合建構複雜應用程式。 layui學習簡單,適合快速建立頁面;Vue學習曲線陡峭,但有助於建立可擴展且易於維護的應用程式。根據專案需求和開發者技能水平,可以選擇合適的框架。

透過使用layui框架的響應式佈局功能,可以實現自適應佈局。步驟包括:引用layui框架。定義自適應佈局容器,設定layui-container類別。使用響應式斷點(xs/sm/md/lg)隱藏特定斷點下的元素。利用網格系統(layui-col-)指定元素寬度。透過偏移量(layui-offset-)建立間距。使用響應式實用工具(layui-invisible/show/block/inline)控制元素的可見性和顯示方式。

使用 layui 傳輸資料的方法如下:使用 Ajax:建立請求對象,設定請求參數(URL、方法、資料),處理回應。使用內建方法:使用 $.post、$.get、$.postJSON 或 $.getJSON 等內建方法簡化資料傳輸。

layui是一個前端UI框架,它提供了豐富的UI元件、工具和功能,幫助開發人員快速建立現代化、響應式和互動式Web應用程序,特點包括:靈活輕量、模組化設計、豐富的元件、強大的工具和易於自訂。它廣泛應用於各種Web應用程式的開發中,包括管理系統、電商平台、內容管理系統、社交網路和行動裝置應用程式。

layui框架是一款基於JavaScript的前端框架,提供了一套易用的UI元件和工具,幫助開發者快速建立響應式網路應用程式。其特點包括:模組化、輕量級、響應式,並擁有完善的文件和社群支援。 layui廣泛應用於管理後台系統、電商網站和行動裝置應用程式等開發。優點在於上手快、提升效率、維護方便,缺點是客製化較差、技術更新較慢。

layui和vue是前端框架,layui是一種輕量級的函式庫,提供UI元件和工具;vue是一個全面的框架,提供UI元件、狀態管理、資料綁定和路由等功能。 layui基於模組化的架構,vue是基於組件化的架構。 layui擁有較小的生態系統,vue擁有龐大且活躍的生態系統。 layui學習曲線較低,vue學習曲線較陡。 layui適用於小型專案和快速開發UI元件,vue適用於大型專案和需要豐富功能的場景。
