1、Bootstrap File Input 是一款非常优秀的HTML5文件上传插件,支持文件预览、多选等一系列特性。基于 Bootstrap File Input v4.3.2 上传文件时,现有参数:upfile、file_id。如图1
2、现在需要新增参数:type,基于单选按钮的选择:视频、音频,设置其对应值:video、audio。如图2
3、参考官网:http://www.bootstrap-fileinput.com/options.html 。配置项:uploadExtraData,将作为数据通过 POST 传递给 url/AJAX 服务器调用的额外数据。 此属性仅适用于 ajax 上传,并且当您为 uploadUrl 设置了值时。如图3
4、编辑 JS 代码,添加:uploadExtraData: {type: ‘video’},。如图4
function initUploadMediaFile(id, type) {
var container = $('body');
if (id) {
container = $(id);
}
var uploadFiles = container.find('input[data-target="uploadMediaFile"]');
$.each(uploadFiles, function (i, v) {
$_self = $(v);
var initialPreview = [];
var initialPreviewConfig = [];
var previewImage = $('input[name="' + $_self.attr('data-for') + '"]').attr('data-preview') || $('input[name="' + $_self.attr('data-for') + '"]').val();
if (previewImage) {
initialPreview.push(previewImage);
initialPreviewConfig.push({key: getFileName(previewImage)})
}
var maxFileSize = 512000;
var msgSizeTooLargeUnit = '512000KB';
$_self.fileinput({
allowedFileTypes: ['video', 'audio'],
language: 'zh',
initialPreview: initialPreview,
initialPreviewConfig: initialPreviewConfig,
showPreview: false,
deleteUrl: '',
// initialPreviewAsData: true,
multiple: false,
maxFileSize: maxFileSize,
msgSizeTooLarge: '建议上传不超过' + msgSizeTooLargeUnit + '大小的图像!',
allowedFileExtensions: ["'" + type + "'"],
uploadUrl: "/web-api/vms/upload",
uploadExtraData: {type: 'video'},
overwriteInitial: true,
dropZoneEnabled: false,
showUpload: false, //是否显示上传按钮
uploadAsync: true
}).on("filebatchselected", function(event, files) {
$(this).fileinput("upload");
}).on('fileuploaded', function (event, data, previewId, index) {
$.isLoading('hide');
if (data.response.code == 0) {
// alert(JSON.stringify(data));
if (typeof window.uploadFilesSuccess !== 'undefined') {
window.uploadFilesSuccess(data.response.id, $(event.target).attr('data-for'));
}
// $('#'+previewId).attr('data-code',getFileName(data.response.result.attachment));
// $('input[name="'+$(event.target).attr('data-for')+'"]').val(data.response.result.original);
$('#' + previewId).attr('data-code', getFileName(data.response.id));
$('input[name="' + $(event.target).attr('data-for') + '"]').val(data.response.id);
} else {
utils.showNotification('上传文件失败', 3);
}
}).on('filecleared', function (event) {
// console.log(event, 1);
$('input[name="' + $(event.target).attr('data-for') + '"]').val('');
}).on('iledeleted', function (event, key) {
$('input[name="' + $(event.target).attr('data-for') + '"]').val('');
}).on('filereset', function (event) {
$('input[name="' + $(event.target).attr('data-for') + '"]').val('');
}).on('filepreupload', function (event) {
$('.kv-upload-progress').show();
$.isLoading({text: '数据提交中,请稍后。。。'});
}).on('filesuccessremove', function (event, id) {
$('input[name="' + $(event.target).attr('data-for') + '"]').val('');
}).on('fileuploaderror', function (event, data, msg) {
$.isLoading('hide');
$('.kv-upload-progress').hide();
utils.showNotification('上传文件失败', 3);
});
})
}
5、测试功能,上传文件时,新增 POST 参数 ( type: video ) 成功实现。如图5
6、在调整此函数时,基于单选按钮的选择,再增加一个函数参数 $type 就可以实现预期的文件类型的效果。function initUploadMediaFile(id, type, filetype) 。符合预期。如图6
原创文章,作者:carmelaweatherly,如若转载,请注明出处:https://blog.ytso.com/tech/webdev/181714.html
