layui对于一些前端小白来说,例如我,真的非常的好用,不用去花很多很多的心思在前端美化中,并且提高了很大的工作效率。所以建议一些觉得自己前端技术不是很强,但是想让前端美化一点的可以使用layui。

layui有开发文档,不用自己去刻意去记一些语法,用的多了,自然就记住了。开发文档链接:https://www.layui.com/doc/

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: ,
ok: function () { self.location.reload(); },
});
d.show();
} else {
layer.closeAll('loading');
var d = dialog({
title: '提示',
content: '上传模板失败',
width: ,
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 - ]);
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上传文件以及数据表格的更多相关文章

  1. WebAPI通过multipart/form-data方式同时上传文件以及数据(含HttpClient上传Demo)

    简单的Demo,用于了解WebAPI如何同时接收文件及数据,同时提供HttpClient模拟如何同时上传文件和数据的Demo,下面是HttpClient上传的Demo界面 1.HttpClient部分 ...

  2. layui上传文件组件(前后端代码实现)

    我个人博客系统上传特色图片功能就是用layui上传文件组件做的.另外采用某个生态框架,尽量都统一用该生态框架对应的解决方案,因为这样一来,有这么几个好处?1.统一而不杂糅,有利于制定相应的编码规范,方 ...

  3. layui上传Excel更新数据并下载

    前言: 最近做项目遇到了一个需求,上传Excel获取数据更新Excel文档,并直接返回更新完的Excel到前端下载:其实需求并没有什么问题,关键是前端用到的是layui上传组件(layui.uploa ...

  4. layui上传文件配合进度条

    首先看一下效果图: 修改layui的源文件upload.js 1.打开layui/modules/upload.js 2.搜索ajax 3.找到url: 4.添加以下代码: ,xhr:l.xhr(fu ...

  5. c# 模拟表单提交,post form 上传文件、数据内容

    转自:https://www.cnblogs.com/DoNetCShap/p/10696277.html 表单提交协议规定:要先将 HTTP 要求的 Content-Type 设为 multipar ...

  6. layui上传文件前加入确认提示

    //上传文件 upload: function () { layui.use('upload', function () { var upload = layui.upload; //执行实例 var ...

  7. vue 上传文件 并以表格形式显示在页面上

    先上代码 <label for="file" class="btn">多文件上传</label> <input type=&quo ...

  8. 使用WebClient Post方式模拟上传文件和数据

    假如某网站有个表单,例如(url: http://localhost/login.aspx):帐号  密码 我们需要在程序中提交数据到这个表单,对于这种表单,我们可以使用 WebClient.Uplo ...

  9. layui上传文件前端报404,实际文件已经上传成功

    原因:上传回调的方法接收的参数应该是json格式的,之前返回的是String,所以一直走异常的方法 第一种 在后台上加上@ResponseBody 第二种 @ResponseBody @Request ...

随机推荐

  1. HTML代码中<%%>、<%=%>、<%:%>

    <%%>之间可以写服务器端代码 比如 <% for(var i=0;i<10;i++){%> <%=%>获取后台的变量值,比如后台一个session[&quo ...

  2. CSS动画效果

    CSS变形效果 Transform translate:平移 translate(x,y) translateX(x) translateY(y)相对于元素原始位置平移. scale:缩放 大于1放大 ...

  3. 如何学习Java?学习Java顺序?

    Java相对于Asp.Net或Asp.Net MVC来讲,入门是比较困难和烦琐的!它不像.Net哪样有安装开发工具就可以跑程序了,不需要配置复杂的运行环境. 推荐的学习Java的学习顺序如下: 一.J ...

  4. TP5.0:引入view视图中公共的模版文件

    1.实例:如后台admin模块,公用一个header.html和footer.hml 2.目录结构: 3.视图页面的使用方式: <!--添加header页面数据-->{include fi ...

  5. Python3条件控制语句

    Python条件语句是通过一条或多条语句的执行结果(True或者False)来决定执行的代码块. if语句 if 条件: 代码块 elif 条件: 代码块 else: 代码块 python中用elif ...

  6. C++11之 Move semantics(移动语义)(转)

    转https://blog.csdn.net/wangshubo1989/article/details/49748703 按值传递的意义是什么? 当一个函数的参数按值传递时,这就会进行拷贝.当然,编 ...

  7. note01-计算机网络

    1.基础概述 三网: 电信网络.有线电视网络.计算机网络(连通&共享) 终端->z本地ISP->x地区IXP->y主干ISP 通信方式: C/S .P2P(即是client也 ...

  8. 面向对象编程(OOP)、面向组件编程(COP)、面向方面编程(AOP)和面向服务编程(SOP)

    http://blog.csdn.net/hjf19790118/article/details/6919265 1.什么是面向对象编程(Object-Oriented Programming)? 面 ...

  9. Did not receive a reply. Possible causes include: the remote application did not send a reply, the message bus security policy blocked the reply, the reply timeout expired,

    Did not receive a reply. Possible causes include: the remote application did not send a reply, the m ...

  10. 2016 China Collegiate Programming Contest Final

    2016 China Collegiate Programming Contest Final Table of Contents 2016 China Collegiate Programming ...