首页 技术 正文
技术 2022年11月9日
0 收藏 898 点赞 1,654 浏览 2634 个字

在做项目是遇到上传图片,并在前端限制图片上传的大小,下面就直接贴出主要的上传图片的代码,以及图片大小的验证,但前端没有验证图片的宽高验证

一、先创建出上传图片的组件,使用filefield组件var upLoadBox = Ext.create('Ext.form.Panel', {
height: 100,
flex: 1,
bodyPadding: 15,
border: 0,
items: [{
xtype: 'filefield',
name: 'photo',
id:'id_fileField_photo',
labelWidth: 50,
msgTarget: 'side',
allowBlank: false,
anchor: '100%',
maxLength: 200,
border: 0,
buttonText: '选择图片',
Verification: "photo",
validator: validateCustom,
regex: null
}],
buttons: [{
text: '上传',
handler: function() {
var form = this.up('form').getForm();
//上传图片时传递的参数
var reqParams = { };
//验证from表单输入是否正确
if (form.isValid()) {
//验证图片大小
if(me.IsValidateSize && validateImageSize()){
Ext.Msg.alert('提示','图片太大,请选择小于'+me.ImageMaxSize+'KB的图片文件!');
return ;
} form.submit({
url: 'https://xxxxxx', //在这里修改为你上传图片的路径
params: reqParams, //这里修改为你上传图片时的参数
waitMsg: '正在上传...',
success: function(fp, o) {
//这里处理上传图片成功后的操作
var msg = o.response.responseText;
if (msg) {
Ext.Msg.alert("温馨提示", msg);
return;
}
},
failure: function(proxy, response) {
//这里处理上传图片失败的操作
response = response.response;
if (response.status == 0) {
Ext.Msg.alert("温馨提示", "网络超时,请重试");
return false;
}
var msg = response.responseText;
if (msg) {
Ext.Msg.alert("温馨提示", msg);
}
}
});
}
}
}]
});
//窗体
var win = new Ext.Window({
title: '请您选择要上传的图片',
name: "winupLoadId",
width: 476,
height: 142,
resizable: false,
modal: true,
closable: true,
items: [upLoadBox]
});
win.show();//上传图片的输入框格式正则验证
var regexs["photo"] = /\.jpg$|\.jpeg$|\.png$/i; //图片格式
var regexsTexts["photo"] = '请选择格式为“png、jpg、jpeg”的图片';
function validateCustom(val) {
if (val != "") {
var fields = this.Verification;
var items = fields.split('|');
for (var i = 0; i < items.length; i++) {
if (regexs[items[i]]) {
if (!regexs[items[i]].test(val)) {
return regexsTexts[items[i]];
}
}
}
}
return true;
}
//验证图片大小
function validateImageSize(){
//取控件DOM对象
var field = document.getElementById('id_fileField_photo');
//取控件中的input元素
var inputs = field.getElementsByTagName('input');
var fileInput = null;
var il = inputs.length;
//取出input 类型为file的元素
for(var i = 0; i < il; i ++){
if(inputs[i].type == 'file'){
fileInput = inputs[i];
break;
}
}
if(fileInput != null){
var fileSize = getFileSize(fileInput);
//允许上传不大于1M的文件
return fileSize > 1024;
}
return false;
},//计算文件大小,返回文件大小值,单位K
function getFileSize(target) {
var isIE = /msie/i.test(navigator.userAgent) && !window.opera;
var fs = 0;
if (isIE && !target.files) {
var filePath = target.value;
var fileSystem = new ActiveXObject("Scripting.FileSystemObject");
var file = fileSystem.GetFile(filePath);
fs = file.Size;
} else if (target.files && target.files.length > 0) {
fs = target.files[0].size;
} else {
fs = 0;
}
if (fs > 0) {
fs = fs / 1024;
}
return fs;
}验证图片的格式可以使用下面的方法
//验证图片文件的正则 
var img_url_value = '';
var img_reg = /\.([jJ][pP][gG]){1}$|\.([jJ][pP][eE][gG]){1}$|\.([gG][iI][fF]){1}$|\.([pP][nN][gG]){1}$|\.([bB][mM][pP]){1}$/;
if(!img_reg.test(img_url_value)){
Ext.Msg.alert('提示','文件类型错误,请选择图片文件(jpe/jpeg/gif/png/bmp)');
}


    					
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,996
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,510
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,353
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,137
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,770
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,848