Bien, en este tip mostraré como podemos hacer funcionar el trim() de AS3 como el trim() de PHP, la diferencia entre estos dos métodos, es que con el de PHP no solo podemos eliminar espacios en blanco la inicio y final de la cadena, sino que podemos definir caracteres que también sean eliminados.
La implementación de este trim() para AS3 fué tomada en base a la clase StringUtils del blog gskinner.
el método original es el siguiente:
Código :
public static function trim(p_string:String):String { if (p_string == null) { return ''; } return p_string.replace(/^\s+|\s+$/g, ''); }
aquí la magia esta en la línea del return, donde le indica al método que regrese lo que reemplace de la cadena según la expresión regular que esta definiendo, lo que hace que elimine los espacios es el caracter \s por lo que este caracter es el que tenemos que sustituir en nuestro nuevo método, además de que tenemos que agregar otro parámetro para definir cual será el caracter a reemplazar, ya modificado el método nos quedaría algo así:
Código :
public static function trimChar(p_string:String, p_char:String = ' '):String { if (!p_string) { return ''; } var regexp:RegExp = new RegExp("^" + p_char + "+|" + p_char + "+$", "g"); return p_string.replace(regexp, ''); }
suponiendo que el método se agregue a una clase llamada StringUtils, la utilización de esta clase sería:
Código :
var foo:String = " lDaniel Daniel "; trace(StringUtils.trimChar(foo)); //lDaniel Daniel trace(StringUtils.trimChar(StringUtils.trimChar(foo), "l")); //Daniel Danie
este método es para eliminar de ambos lados de la cadena, si solo se quisiera eliminar de un solo lado, se reemplaza el valor de la variable regexp según sea necesario o bien, se crean dos métodos nuevos cada uno con cada definición de la variable:
Código :
//para hacer un trim de lado izquierdo var regexp:RegExp = new RegExp("^" + p_char + "+", "g"); //para hacer un trim de lado derecho var regexp:RegExp = new RegExp(p_char + "+$", "g");
Espero que les sirva, Saludos!
¿Sabes SQL? ¿No-SQL? Aprende MySQL, PostgreSQL, MongoDB, Redis y más con el Curso Profesional de Bases de Datos que empieza el martes, en vivo.
Por Gz.Francisco el 08 de Enero de 2010
Buen tip =D
Por Freddie el 12 de Enero de 2010
Por solisarg el 14 de Julio de 2011
Jorge