layui在表格中嵌入上传按钮并修改上传进度条的实例

 更新时间:2024年07月05日 11:20:48   作者:学习做游戏中  
这篇文章主要介绍了layui在表格中嵌入上传按钮并修改上传进度条的实例,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧

当需要在表格中添加上传文件按钮,并不需要弹出填写表单的框的时候,需要在layui中,用按钮触发文件选择
有一点需要说明的是,layui定义table并不是在定义的标签中渲染,而是在紧接着的标签中渲染,所以要获取实例,要用 next()
也可以通过this或者css选择器来获取实例

效果展示

根据后端数据展示不同按钮

点击上传直接弹出文件选择框

点击上传后直接在屏幕中央显示进度,因为是遮罩层

思路

  • 在table.render中添加上传按钮
  • 表格加载完成后,给按钮绑定upload.render
  • 通过给按钮中添加属性,来获取表单中想要传递的值

关键代码

因为是django项目结合的layui,所以只放出关键的代码
通过后端传递过来的数据,多条件判断,渲染表格中的内容

<script type="text/html" id="xls_bar">
        <div class="layui-clear-space">
            {% verbatim  %}
            {{# if((d.has_xls)==1){ }}
            <span>已上传</span>
            {{# }else if((d.user==d.name) & (d.has_xls==0)) { }}
            <button class="layui-btn layui-btn-xs demo-class-accept" id="up_xls" value="{{=d.form_id}}" acti="{{=d.activities}}" lay-options="{
                accept: 'file',
                exts: 'xls|xlsx'
              }">上传成绩</button>
            {{# }else { }}
            <span>未上传</span>
            {{# } }}
            {% endverbatim  %}
        </div>
      </script>

渲染table,与其中的按钮触发

var inst = table.render({
            elem: '#ID-table-demo-data',
            url: 'all_forms/',
            cols: [[
              {field: 'unit__name', title: '单位', width: 180},
              {field: 'name', title: '装置', width: 220},
              {field: 'title', title: '演练项目', templet:'#add_title'},
              {field: 'has_xls', title: '成绩', width: 220,templet:'#xls_bar'},
              {field: 'has_mp4', title: '视频', width: 280,templet:'#mp4_bar'}
            ]],
            error: function(e, msg) {
                console.log("返回错误",e, msg)
                $(".layui-table-main").html('<div class="layui-none">无数据</div>');      
            },
            done: function(res, curr, count) {
            console.log("前端获取到的数据是:",res.data);
            alarmTableRowSpan("unit__name", 1);
            upload.render({
                elem: '#up_xls', // 绑定多个元素
                url: '/add_title/', // 此处配置你自己的上传接口即可
                accept: 'file', // 普通文件
                before: function(obj){ //obj包含信息,跟choose回调完全一致。在传值之前先获取id
                    var tableElem = this.item;
                    console.log("点击选中的当前行数据",tableElem);
                    uploadParam = tableElem.attr('value');
                    uploadParam2 = tableElem.attr('acti');
                    console.log("点击选中的当前行数据1",uploadParam);
                    console.log("点击选中的当前行数据2",uploadParam2);
                    // layer.load(); //上传loading
                    layer.open({
                        type: 1,
                        area: 'auto',
                        resize: false,
                        shadeClose: false,
                        title: false,
                        closeBtn: 0,
                        content: `
                            <div class="my-context" id="up_percent">00%</div>
                            `
                    });
                },
                data: {
                    form_id: function () {//data中写值的时候,要用动态获取的方式,即写个function的方式,不然直接写获取不到相应的值。
                        return uploadParam;
                    },
                    activitie: function () {//data中写值的时候,要用动态获取的方式,即写个function的方式,不然直接写获取不到相应的值。
                        return uploadParam2;
                    },
                    "csrfmiddlewaretoken": csrf_token
                },
                done: function(res){
                    if(res.code == 0){
                        layer.closeAll('loading'); //关闭loading
                        location.reload();
                        return layer.msg('上传成功');
                    }
                  console.log(res);
                },
                progress: function(n, elem, e){
                    $('#up_percent').text(n+'%')
                    if(n == 100){
                      layer.msg('上传完毕', {icon: 1});
                    }
                  }
              });
              upload.render({
                elem: '#up_mp4', // 绑定多个元素
                url: '/add_title/', // 此处配置你自己的上传接口即可
                accept: 'file', // 普通文件
                before: function(obj){ //obj包含信息,跟choose回调完全一致。在传值之前先获取id
                    var tableElem = this.item;
                    console.log("点击选中的当前行数据",tableElem);
                    uploadParam = tableElem.attr('value');
                    uploadParam2 = tableElem.attr('acti');
                    console.log("点击选中的当前行数据1",uploadParam);
                    console.log("点击选中的当前行数据2",uploadParam2);
                    // layer.load(); //上传loading
                    layer.open({
                        type: 1,
                        area: 'auto',
                        resize: false,
                        shadeClose: false,
                        title: false,
                        closeBtn: 0,
                        content: `
                            <div class="my-context" id="up_percent">00%</div>
                            `
                    });
                },
                data: {
                    form_id: function () {//data中写值的时候,要用动态获取的方式,即写个function的方式,不然直接写获取不到相应的值。
                        return uploadParam;
                    },
                    activitie: function () {//data中写值的时候,要用动态获取的方式,即写个function的方式,不然直接写获取不到相应的值。
                        return uploadParam2;
                    },
                    "csrfmiddlewaretoken": csrf_token
                },
                done: function(res){
                    if(res.code == 0){
                        layer.closeAll('loading'); //关闭loading
                        location.reload();
                        return layer.msg('上传成功');
                    }
                  console.log(res);
                },
                progress: function(n, elem, e){
                    $('#up_percent').text(n+'%')
                    console.log(n)
                    if(n == 100){
                      layer.msg('上传完毕', {icon: 1});
                    }
                  }
              });
            }
          });

<div class="my-context" id="up_percent"></div> 定义了弹出层,用jq动态改变其中的内容,显示上传进度,但是布局中,原因是弹出的layer,如果中间不放任何内容的话,再动态添加内容就不居中了,解决办法是初始化内容 00%
欢迎大家在评论区提问

到此这篇关于layui在表格中嵌入上传按钮,并修改上传进度条的文章就介绍到这了,更多相关layui上传进度条内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Javascript弹出窗口的各种方法总结

    Javascript弹出窗口的各种方法总结

    这篇文章介绍了Javascript弹出窗口的各种方法总结,有需要的朋友可以参考一下
    2013-11-11
  • 微信小程序flex-grow无效的解决方案

    微信小程序flex-grow无效的解决方案

    在微信小程序中使用 Flexbox 布局时,如果遇到 flex-grow 属性无效的情况,可能是由几个不同的原因导致的,以下是一些可能的原因和解决方案,感兴趣的朋友一起看看吧
    2024-08-08
  • 分享12个Webpack中常用的Loader(小结)

    分享12个Webpack中常用的Loader(小结)

    这篇文章主要介绍了分享12个Webpack中常用的Loader(小结),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • JavaScript数组的使用详解

    JavaScript数组的使用详解

    这篇文章主要介绍了JavaScript数组的使用方法,数组(Array)是有序的元素序列。若将有限个类型相同的变量的集合命名,那么这个名称为数组名,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • 关于JavaScript的单双引号嵌套问题

    关于JavaScript的单双引号嵌套问题

    单引号和双引号之间可以相互嵌套。接下来通过本文给大家介绍JavaScript的单双引号嵌套问题 ,感兴趣的朋友一起看看吧
    2017-08-08
  • JS解决url传值出现中文乱码的另类办法

    JS解决url传值出现中文乱码的另类办法

    为什么用表单的方式就可以传递中文,而URL的方式就不行了呢?非得用URL传值的方式才能解决问题吗?这里我想到了动态表单,何不用它来解决呢
    2013-04-04
  • ES6使用 Array.includes 处理多重条件用法实例分析

    ES6使用 Array.includes 处理多重条件用法实例分析

    这篇文章主要介绍了ES6使用 Array.includes 处理多重条件用法,结合实例形式分析了Array.includes基本功能、原理及处理多重条件相关操作技巧,需要的朋友可以参考下
    2020-03-03
  • JS箭头函数和常规函数之间的区别实例分析【 5 个区别】

    JS箭头函数和常规函数之间的区别实例分析【 5 个区别】

    这篇文章主要介绍了JS箭头函数和常规函数之间的区别,结合实例形式分析了JS箭头函数和常规函数之间的 5 个区别与相关使用注意事项,需要的朋友可以参考下
    2020-05-05
  • 通过JAVASCRIPT读取ASP设定的COOKIE

    通过JAVASCRIPT读取ASP设定的COOKIE

    通过JAVASCRIPT读取ASP设定的COOKIE...
    2007-02-02
  • js漂浮广告实现代码

    js漂浮广告实现代码

    js漂浮广告实现代码,本质上就是一个来回滚动的小图片,也是一种广告形式,需要的朋友可以收藏下
    2015-08-08

最新评论