layui的upload动态数据事件绑定

文章讲述了在列表中替换视频封面时,遇到上传按钮渲染问题的解决方案,包括尝试过通过class批量渲染、针对每个ID单独渲染,最终采用隐藏上传按钮并重载参数的方式,解决了layuiupload.js中的用户激活错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题背景:有一个列表中需要对已有视频进行更换封面图,视频列表加载之后在每一个视频上加了一个上传文件的按钮,但是按钮怎么都渲染不上事件,试了几种办法

第一种、通过class类来给元素批量渲染,对于加载出来的元素无效

第二种、在接口返回中针对每一个id分别渲染,第一次加载出来的数据可以正常上传,但是列表刷新后,就不行了

后来在网上找了好多,有一个老哥给了我思路,就是定义一个隐藏的上传按钮,然后通过对upload的重载进行参数控制。

<input id="videoCoverUrl" type="input" class="layui-hide">

//上传视频封面
var coverupload = upload.render({
    elem: '#videoCoverUrl' //绑定元素
    , multiple: false
    , auto: false
    , headers: os.getToken()
    , size: 3072
    , number: 5
    , progress: function (value) {//上传进度回调 value进度值
        element.progress('uppro', value + '%');
        if (value === 100) {
            vm.upStatus = 'layui-hide';
        }
    }
    , exts: 'jpg|png|gif|bmp|jpeg'
    , url: '/api/localfiles/upload' //上传接口
    , data: {
        //path: function () { return $('#localpath').val() }
        
    }, choose: function (obj) {
        //预读本地文件
        obj.preview(function (index, file, result) {
            //let data = '@Model.SavePath';
            //if (data != null && data != undefined && data != '') {
            //    parent.vm.$imgData = data
            //}
            parent.vm.$imgData = [result, file.name];
            parent.vm.$layuploadobj = obj;
            os.OpenCropper(750, 450);
        })
    }
    , before: function () {
        vm.upStatus = 'layui-show';
    }
    , done: function (res) {
        if (res.statusCode === 200) {
            os.success('上传成功~');
            vm.list = [];
            oc.initLocal();
        } else {
            vm.upStatus = 'layui-hide';
            os.error(res.message);
        }

    }
    , error: function () {
        vm.upStatus = 'layui-hide';
        os.error('上传失败');
    }
});

在那个老哥的方法中使用了
    $("#uploadMeetBtn").click();

来触发点击事件,但是现在使用这种方式触发点击事件会在layui的upload中报错:

upload.js:2 File chooser dialog can only be shown with a user activation.

后面又试了好多方式,网上有说需要给点击事件增加延迟,延迟500-1500毫秒,都不好使,最后试着重新获取元素,然后对元素直接点击反而又行了,就很莫名其妙。一下是重载方法的实现,再此记录

coverupload: function (m) {
    form.render();
    coverupload.reload({
        data:{
            id: m.guid,
            type:2
    }
    });
    var input = document.getElementById('videoCoverUrl');
    input.click();
}

### Layui Upload 组件与 Flask 后端交互传递参数 在Web开发中,前端框架与后端服务之间的通信至关重要。当使用Layui的上传组件与Flask作为后端时,可以通过配置`data`字段来向服务器传递额外参数[^2]。 #### 前端实现 (HTML + JavaScript) 为了使Layui上传组件能够携带自定义参数到Flask后台,在初始化该插件的时候可以设置`field`属性指定文件域名称,并通过`data`选项添加其他想要发送的信息: ```html <!-- HTML --> <form class="layui-form"> <div class="layui-form-item"> <label class="layui-form-label">图片</label> <div class="layui-input-block"> <!-- lay-data 是必填项 --> <button type="button" class="layui-btn" id="test1">上传图片</button> </div> </div> </form> <script src="/static/layui/layui.js"></script> <script> layui.use('upload', function(){ var upload = layui.upload; // 执行实例 upload.render({ elem: '#test1' // 绑定元素 ,url: '/upload' // 接收上传文件的服务接口路径 ,method:'post' ,data:{token:'mysecretkey'} // 自定义参数 ,done: function(res){ console.log(res); } }); }); </script> ``` 上述代码片段展示了如何利用Layui的API创建一个带有附加参数(如`token='mysecretkey'`)的文件上传表单。 #### 后端接收 (Python - Flask) 对于接收到这些来自客户端的数据,可以在Flask视图函数里解析请求中的表单数据和文件流。下面是一个简单的例子说明怎样获取并保存上传来的图像文件及其关联的元数据: ```python from flask import request, jsonify import os @app.route('/upload', methods=['POST']) def upload_file(): if 'file' not in request.files or 'token' not in request.form: return jsonify({'error': 'No file part'}) file = request.files['file'] token = request.form.get('token') if file.filename == '': return jsonify({'error': 'No selected file'}) filename = secure_filename(file.filename) filepath = os.path.join(app.config['UPLOAD_FOLDER'], filename) file.save(filepath) response_data = { "message": f"{filename} has been uploaded successfully.", "path": filepath, "received_token": token } return jsonify(response_data), 200 ``` 这段脚本首先验证是否存在必要的输入项——即文件本身以及随同上传过程一起提交的身份令牌;接着读取它们的内容并将文件存储于服务器本地磁盘之上;最后构建JSON格式的消息反馈给调用方告知操作结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值