terça-feira, 20 de maio de 2008

Code Snippets pra todos os gostos

Bom pessoal, ando meio sumido ultimamente. Dando uma olhada num Silverlight aqui, um WPF ali e com o intuito de não publicar algo errado fico postergando o dia em que vou escrever algo de útil para a comunidade. Pois bem, numa das minhas várias leituras do dia me deparei com um site bem interessante, onde podemos encontrar vários code snippets para baixar e inclusive fazer upload de algum que tenhamos feito. É o GotCodeSnippets.com. Têm vários que só devem estar sendo usados por quem criou mesmo, mas tem muita coisa útil também. Enjoy

terça-feira, 26 de fevereiro de 2008

Extension Methods

Imagine a seguinte situação: Você tem uma aplicação que faz um cálculo qualquer. Para isso pega o valor de duas TextBox e apresenta o resultado em um Label. O que devemos ter cuidado é que C# é uma linguagem de programação de tipagem forte (strongly typed). Ao receber os dados dos TextBox você tem que primeiro converte-los para inteiros (neste caso). Aproveitando o código, validei a entrada de caracteres inválidos com o método TryParse da Classe Int32, que, em caso de falha na conversão nos retorna o valor padrão do Int32, ou seja, o “0”.

using System;

public partial class _Default : System.Web.UI.Page

{

protected void Button1_Click(object sender, EventArgs e)

{

int numero1;

int numero2;

Int32.TryParse(TextBox1.Text, out numero1);

Int32.TryParse(TextBox2.Text, out numero2);

Label1.Text = (numero1 + numero2).ToString();

}

}

No entanto, com os Extensions Methods podemos tornar nossa tarefa mais fácil. Cria uma nova classe e coloque o código como abaixo:

using System;

namespace Vitor.Canova.NET

{

public static class Extensoes

{

public static int ToInteger(this string field)

{

int valor;

Int32.TryParse(field, out valor);

return valor;

}

}

}

Pronto, nosso método vai extender a toda e qualquer string que for utilizada graças a palavra this no início da declaração dos parâmetros. Ela avisa ao compilador que aquele método pode ser usado por qualquer objeto do tipo defifido após essa palavra, no caso uma string. Agora vejamos como fica o código da página:

using System;

using Vitor.Canova.NET;

public partial class _Default : System.Web.UI.Page

{

protected void Button1_Click(object sender, EventArgs e)

{

Label1.Text = (

TextBox1.Text.ToInteger() +

TextBox2.Text.ToInteger()

).ToString();

}

}

Como podemos ver, o método pode ser invocado como se já pertencesse ao tipo string nos facilitando a conversão, sem falor no fato do Intellisense mostrar ele na lista de opções. Alguns fatos que devemos prestar atenção é o fato da classe é método de extensão serem do tipo static, o que faz com que não precisemos instanciar a classe para utiliza-la. Vale lembrar que foi adicionado o namespace da classe a página que vai utiliza-la também.

segunda-feira, 28 de janeiro de 2008

Planilha ASP.NET

Férias não tão longas quanto gostaria mas consegui relaxar um pouco. O problema é que acabei deixando o Blog um pouco de lado. Mas pra recompensar aí vai uma dica bem legal. Hoje vou ensinar um truque que aprendi lendo um post do Mauricio Junior no site www.juliobattisti.com.br. Ele ensina como modificar uma página aspx para que o Browser interprete-a como um arquivo Excel. Quando fui fazer o mesmo pela primeira vez, vi que a lógica estava principalmente no ContentType da página, que foi alterada para application/vnd.ms-excel. Bom, vamos lá é bem fácil. Crie uma página aspx normal e coloque uma tabela html com os dados que você quer no Excel, eu a chamei de Planilha. Rode o projeto. O Código e a página devem parecer como estas abaixo: Logo após crie uma página com um link para Planilha.aspx. Na diretiva Page de Planilha.aspx coloque ContentType="application/vnd.ms-excel" e certifique-se que a ViewState está desabilitada. Rode novamente o projeto e clique no link. O Browser, ao acessar a Planilha.aspx vai interpretá-la como um arquivo Excel e vai fazer o seu Download.