Foros del Web » Programando para Internet » Javascript » Frameworks JS »

limpiar codigo de upload, dejar lo esencial y manipularlo

Estas en el tema de limpiar codigo de upload, dejar lo esencial y manipularlo en el foro de Frameworks JS en Foros del Web. hola forer@s Tengo mínimos conocimientos en jquery he logrado hacer varias cosillas pero esto me supera, verán, tengo un formulario que valida y envía las ...
  #1 (permalink)  
Antiguo 16/02/2012, 11:42
Avatar de catpaw  
Fecha de Ingreso: mayo-2010
Ubicación: xalapa
Mensajes: 856
Antigüedad: 14 años, 7 meses
Puntos: 23
limpiar codigo de upload, dejar lo esencial y manipularlo

hola forer@s

Tengo mínimos conocimientos en jquery he logrado hacer varias cosillas pero esto me supera, verán, tengo un formulario que valida y envía las variables por ajax a php, acá todo perfecto.

Ahora necesito poder subir al menos 5 imágenes en el mismo formulario, encontré un cogido jquery que lo hace sin problema, pero necesito adaptarlo al código que ya tengo, este es mi funcion ajax para traer los valores del form:

Código:
function procesar_form(){
   //recibo variables
   var variable1= document.getElementById('nombre').value;
   var variable2= document.getElementById('apellido').value;
   //... demás variables
   var variableN= document.getElementById('campoN').value;

       //hago validaciones
       if (variable1==""){
		alert("falta nombre");
	}
	else{
		if (variable2==""){
			alert("falta apellido");
		}
               //... más validaciones
		else{
                       //si todo sale bien envio valores
                       var ajax;
                       ajax= ajaxFunction();
                       ajax.open("GET", "ruta/procesar_form.php?variable1="+variable1+"&variable2="+variable2+"&variableN="+variableN, true);
                       ajax.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
                       ajax.onreadystatechange = function() {
                               if (ajax.readyState == 1){
                                      document.getElementById('form_capa').innerHTML= "<center>Procesando opiniòn, espere por favor...</center>";
                              }
                              if (ajax.readyState==4){
                                      if(ajax.status==200){
                                            document.getElementById('form_capa').innerHTML= ajax.responseText;
                              }
                }
	ajax.send(null);
}
en mi form nada mas llamo la funcion en el boton enviar:

<input type="button" id="enviar" value="Enviar" onclick="procesar_opinion()" />

Ahora eso funciona bien, el codigo del upload de jquery es el siguiente, primero en la pagina donde esta mi form se agrega en el head esto:

Código:
<script src="../js/jquery.uploadify.js" type="text/javascript"></script>
<script type="text/javascript">
$(document).ready(function() {
	$("#img_up").fileUpload({
		'uploader': 'upload/uploader.swf',
		'cancelImg': 'upload/cancel.png',
		'script': 'upload/upload.php',
		'folder': 'files',
		'multi': true,
		'buttonText': 'Examinar...',
		'checkScript': 'upload/check.php',
		'displayData': 'speed',
		'simUploadLimit': 5
	});
});
</script>
img_up es un div vacio: <div id="img_up"></div> que se agrega en el formulario
  #2 (permalink)  
Antiguo 16/02/2012, 11:50
Avatar de catpaw  
Fecha de Ingreso: mayo-2010
Ubicación: xalapa
Mensajes: 856
Antigüedad: 14 años, 7 meses
Puntos: 23
Respuesta: limpiar codigo de upload, dejar lo esencial y manipularlo

y el archivo js que hace todo el rollo del upload es este:

Código:
var flashVer=-1;
if(navigator.plugins!=null&&navigator.plugins.length>0){
	if(navigator.plugins["Shockwave Flash 2.0"]||navigator.plugins["Shockwave Flash"]){
		var swVer2=navigator.plugins["Shockwave Flash 2.0"]?" 2.0":"";
		var flashDescription=navigator.plugins["Shockwave Flash"+swVer2].description;
		var descArray=flashDescription.split(" ");
		var tempArrayMajor=descArray[2].split(".");
		var versionMajor=tempArrayMajor[0];
		var versionMinor=tempArrayMajor[1];
		var versionRevision=descArray[3];
		if(versionRevision==""){
			versionRevision=descArray[4]
		}
		if(versionRevision[0]=="d"){
			versionRevision=versionRevision.substring(1)
		}
		else{
			if(versionRevision[0]=="r"){
				ersionRevision=versionRevision.substring(1);
				if(versionRevision.indexOf("d")>0){
					versionRevision=versionRevision.substring(0,versionRevision.indexOf("d"))
				}
			}
		}
		var flashVer=versionMajor+"."+versionMinor+"."+versionRevision
	}
}
else{
	if($.browser.msie){
		var version;
		var axo;
		var e;
		try{
			axo=new ActiveXObject("ShockwaveFlash.ShockwaveFlash.7");
			version=axo.GetVariable("$version")
		}
		catch(e){}
		flashVer=version.replace("WIN ","").replace(",",".")
	}
}
flashVer=flashVer.split(".")[0];

if(jQuery){
	(function(a){a.extend(a.fn,{fileUpload:function(b){
	if(flashVer>=9){
		a(this).each(function(){settings=a.extend({
			uploader:"uploader.swf",
			script:"uploader.php",
			folder:"",
			height:30,
			width:110,
			cancelImg:"cancel.png",
			wmode:"opaque",
			scriptAccess:"sameDomain",
			fileDataName:"Filedata",
			displayData:"percentage",
			onInit:function(){},
			onSelect:function(){},
			onCheck:function(){},
			onCancel:function(){},
			onError:function(){},
			onProgress:function(){},
			onComplete:function(){}
		},b);
		var d=location.pathname;
		d=d.split("/");
		d.pop();
		d=d.join("/")+"/";var f="&pagepath="+d;
		if(settings.buttonImg){
			f+="&buttonImg="+escape(settings.buttonImg)
		}
		if(settings.buttonText){
			f+="&buttonText="+escape(settings.buttonText)
		}
		if(settings.rollover){
			f+="&rollover=true"
		}
		f+="&script="+settings.script;
		f+="&folder="+escape(settings.folder);
		if(settings.scriptData){
			var g="";
			for(var c in settings.scriptData){
				g+="&"+c+"="+settings.scriptData[c]
			}
			f+="&scriptData="+escape(g)
		}
		f+="&btnWidth="+settings.width;
		f+="&btnHeight="+settings.height;
		f+="&wmode="+settings.wmode;
		if(settings.hideButton){
			f+="&hideButton=true"
		}
		if(settings.fileDesc){
			f+="&fileDesc="+settings.fileDesc+"&fileExt="+settings.fileExt
		}
		if(settings.multi){
			f+="&multi=true"
		}
		if(settings.auto){
			f+="&auto=true"
		}
		if(settings.sizeLimit){
			f+="&sizeLimit="+settings.sizeLimit
		}
		if(settings.simUploadLimit){
			f+="&simUploadLimit="+settings.simUploadLimit
		}
		if(settings.checkScript){
			f+="&checkScript="+settings.checkScript
		}
		if(settings.fileDataName){
			f+="&fileDataName="+settings.fileDataName
		}
		if(a.browser.msie){
			flashElement='<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" width="'+settings.width+'" height="'+settings.height+'" id="'+a(this).attr("id")+'Uploader" class="fileUploaderBtn"><param name="movie" value="'+settings.uploader+"?fileUploadID="+a(this).attr("id")+f+'" /><param name="quality" value="high" /><param name="wmode" value="'+settings.wmode+'" /><param name="allowScriptAccess" value="'+settings.scriptAccess+'"><param name="swfversion" value="9.0.0.0" /></object>'
		} 
		else{
			flashElement='<embed src="'+settings.uploader+"?fileUploadID="+a(this).attr("id")+f+'" quality="high" width="'+settings.width+'" height="'+settings.height+'" id="'+a(this).attr("id")+'Uploader" class="fileUploaderBtn" name="'+a(this).attr("id")+'Uploader" allowScriptAccess="'+settings.scriptAccess+'" wmode="'+settings.wmode+'" type="application/x-shockwave-flash" />'
		}
		if(settings.onInit()!==false){
			a(this).css("display","none");
			if(a.browser.msie){
				a(this).after('<div id="'+a(this).attr("id")+'Uploader"></div>');
				document.getElementById(a(this).attr("id")+"Uploader").outerHTML=flashElement
			}
			else{
				a(this).after(flashElement)
			}
			a("#"+a(this).attr("id")+"Uploader").after('<div id="'+a(this).attr("id")+'Queue" class="fileUploadQueue"></div>')
		}
		a(this).bind("rfuSelect",{
			action:settings.onSelect},
			function(j,h,i){
				if(j.data.action(j,h,i)!==false){
					var k=Math.round(i.size/1024*100)*0.01;
					var l="KB";
					if(k>1000){
						k=Math.round(k*0.001*100)*0.01;
						l="MB"
					}
					var m=k.toString().split(".");
					if(m.length>1){
						k=m[0]+"."+m[1].substr(0,2)
					}
					else{
						k=m[0]
					}
					if(i.name.length>20){
						fileName=i.name.substr(0,20)+"..."
					}
					else{
						fileName=i.name}a("#"+a(this).attr("id")+"Queue").append('<div id="'+a(this).attr("id")+h+'" class="fileUploadQueueItem"><div class="cancel"><a href="javascript:$(\'#'+a(this).attr("id")+"').fileUploadCancel('"+h+'\')"><img src="'+settings.cancelImg+'" border="0" /></a></div><span class="fileName">'+fileName+" ("+k+l+')</span><span class="percentage">&nbsp;</span><div class="fileUploadProgress" style="width: 100%;"><div id="'+a(this).attr("id")+h+'ProgressBar" class="fileUploadProgressBar" style="width: 1px; height: 3px;"></div></div></div>')
					}
			});
			if(typeof(settings.onSelectOnce)=="function"){
				a(this).bind("rfuSelectOnce",settings.onSelectOnce)
			}
			a(this).bind("rfuCheckExist",{
				action:settings.onCheck},
				function(m,l,j,k,o){
					var i=new Object();
					i.folder=d+k;
					for(var h in j){
						i[h]=j[h];
						if(o){
							var n=h
						}
					}
				a.post(l,i,function(r){
					for(var p in r){
						if(m.data.action(m,l,j,k,o)!==false){
							var q=confirm("Do you want to replace the file '"+r[p]+"'?");
							if(!q){
								document.getElementById(a(m.target).attr("id")+"Uploader").cancelFileUpload(p)
							}
						}
					}
					if(o){
						document.getElementById(a(m.target).attr("id")+"Uploader").startFileUpload(n,true)
					}
					else{
						document.getElementById(a(m.target).attr("id")+"Uploader").startFileUpload(null,true)
					}
				},"json")
			});
			a(this).bind("rfuCancel",{
				action:settings.onCancel
			},
			function(j,h,i,k){
				if(j.data.action(j,h,i,k)!==false){
					a("#"+a(this).attr("id")+h).fadeOut(250,function(){
						a("#"+a(this).attr("id")+h).remove()
					})
				}
			});
			a(this).bind("rfuClearQueue",{
				action:settings.onClearQueue
			},
			function(){
				if(event.data.action()!==false){
					a("#"+a(this).attr("id")+"Queue").contents().fadeOut(250,function(){
						a("#"+a(this).attr("id")+"Queue").empty()
					})
				}
			});
			a(this).bind("rfuError",{
				action:settings.onError
			},
			function(k,h,j,i){
				if(k.data.action(k,h,j,i)!==false){
					a("#"+a(this).attr("id")+h+" .fileName").text(i.type+" Error - "+j.name);
					a("#"+a(this).attr("id")+h).css({border:"3px solid #FBCBBC","background-color":"#FDE5DD"})
				}
			});
			a(this).bind("rfuProgress",{
				action:settings.onProgress,toDisplay:settings.displayData
			},
			function(j,h,i,k){
				if(j.data.action(j,h,i,k)!==false){
					a("#"+a(this).attr("id")+h+"ProgressBar").css("width",k.percentage+"%");
					if(j.data.toDisplay=="percentage"){
						displayData=" - "+k.percentage+"%"
					}
					if(j.data.toDisplay=="speed"){
						displayData=" - "+k.speed+"KB/s"
					}
					if(j.data.toDisplay==null){
						displayData=" "}a("#"+a(this).attr("id")+h+" .percentage").text(displayData)
					}
				});
				a(this).bind("rfuComplete",{
					action:settings.onComplete
				},
				function(k,h,j,i,l){
					if(k.data.action(k,h,j,unescape(i),l)!==false){
						a("#"+a(this).attr("id")+h).fadeOut(250,function(){
							a("#"+a(this).attr("id")+h).remove()});
							a("#"+a(this).attr("id")+h+" .percentage").text(" - Completed")}});
							if(typeof(settings.onAllComplete)=="function"){
								a(this).bind("rfuAllComplete",settings.onAllComplete)
							}
						})
					}
				},
				fileUploadSettings:function(b,c){
					a(this).each(function(){
						document.getElementById(a(this).attr("id")+"Uploader").updateSettings(b,c)
					})
				},
				fileUploadStart:function(b){
					a(this).each(function(){
						document.getElementById(a(this).attr("id")+"Uploader").startFileUpload(b,false)
					})
				},
				fileUploadCancel:function(b){
					a(this).each(function(){
						document.getElementById(a(this).attr("id")+"Uploader").cancelFileUpload(b)
					})
				},
				fileUploadClearQueue:function(){
					a(this).each(function(){
						document.getElementById(a(this).attr("id")+"Uploader").clearFileUploadQueue()
					})
				}
			})
		})(jQuery)};
Disculpen tanto codigo, pero es precisamente lo que quiero evitar, y es que si se fijan, el script pide un botón swf que la verdad a mi me estorba ya que el código se basa mucho en eso, comprueba el plugin de flash y muchas cosas, la verdad si se puede dejar a un lado lo del botón flash mejor

tambien hay que agregar dos paginas php, la imagen de cancel y el boton flash

y bueno la pregunta es como incluyo en mi codigo ajax lo siguiete:

que compruebe el tamaño maximo y peso de las imagenes, si eso esta ok que las suba, se que la linea para subir las imagenes es esta:

<a href="javascript:$('#img_up').fileUploadStart()">S ubir Archivo(s)</a>

lo trate de poner en mi ajax antes del ajax.open:

$('#img_up').fileUploadStart();

no marco error pero tampoco subio nada


les agradecería infinitamente su ayuda
  #3 (permalink)  
Antiguo 16/02/2012, 19:51
Avatar de catpaw  
Fecha de Ingreso: mayo-2010
Ubicación: xalapa
Mensajes: 856
Antigüedad: 14 años, 7 meses
Puntos: 23
Respuesta: limpiar codigo de upload, dejar lo esencial y manipularlo

Cita:
que compruebe el tamaño maximo y peso de las imagenes, si eso esta ok que las suba
Bueno en la documentación del uploadify encontré como hacer las validaciones

Ya dejar a un lado lo del botón flash eso es lo de menos y por lo que he leído de este plugin la parte de flash es indispensable.

lo único que necesito saber es como llamar la función que sube las imágenes en mi código ajax, como puedo lanzar esto desde ajax:

<a href="javascript:$('#file_upload').uploadifyUpload ();">Subir Imagenes</a>

como ponerlo en alguna de esta parte del código donde manda todo al php

Código HTML:
//si todo sale bien envio valores
                       var ajax;
                       ajax= ajaxFunction();
                       ajax.open("GET", "ruta/procesar_form.php?variable1="+variable1+"&variable2="+variable2+"&variableN="+variableN, true);
                       ajax.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
                       ajax.onreadystatechange = function() {
                               if (ajax.readyState == 1){
                                      document.getElementById('form_capa').innerHTML= "<center>Procesando opiniòn, espere por favor...</center>";
                              }
                              if (ajax.readyState==4){
                                      if(ajax.status==200){
                                            document.getElementById('form_capa').innerHTML= ajax.responseText;
                              }
                }
Gracias

Etiquetas: ajax, formulario, funcion, html, input, js, limpiar, php, botones
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 02:17.