<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>JulioGreff.net &#187; jquery</title>
	<atom:link href="http://juliogreff.net/tag/jquery/feed/" rel="self" type="application/rss+xml" />
	<link>http://juliogreff.net</link>
	<description>A mesma web, um novo estilo de desenvolvimento</description>
	<lastBuildDate>Sat, 07 May 2011 17:07:10 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.2.1</generator>
		<item>
		<title>Interfaces de Usuário com JavaScript</title>
		<link>http://juliogreff.net/interfaces-de-usuario-com-javascript/</link>
		<comments>http://juliogreff.net/interfaces-de-usuario-com-javascript/#comments</comments>
		<pubDate>Mon, 25 Aug 2008 11:00:42 +0000</pubDate>
		<dc:creator>Julio Greff</dc:creator>
				<category><![CDATA[Destaques]]></category>
		<category><![CDATA[JavaScript]]></category>
		<category><![CDATA[bibliotecas]]></category>
		<category><![CDATA[dojo]]></category>
		<category><![CDATA[ext]]></category>
		<category><![CDATA[jquery]]></category>
		<category><![CDATA[mootools]]></category>
		<category><![CDATA[prototype]]></category>
		<category><![CDATA[ui]]></category>
		<category><![CDATA[yui]]></category>

		<guid isPermaLink="false">http://juliogreff.blog.br/?p=185</guid>
		<description><![CDATA[A web vai se tornando uma plataforma cada vez mais próximas das aplicações desktop que temos. Temos várias aplicações por aí para provar isso. Mas aos olhos do usuário, uma aplicação só com XHTML+CSS às vezes pode não ser tão interessante. De uns tempos pra cá, entretanto, várias bibliotecas surgiram para acabar com esse problema, [...]

<h3>Posts Relacionados</h3><ul><li><a href='http://juliogreff.net/mootools-vs-jquery/' rel='bookmark' title='Permanent Link: Mootools vs. jQuery'>Mootools vs. jQuery</a></li>
<li><a href='http://juliogreff.net/estendendo-o-javascript/' rel='bookmark' title='Permanent Link: Estendendo o JavaScript'>Estendendo o JavaScript</a></li>
<li><a href='http://juliogreff.net/historico-para-navegacao-via-javascript/' rel='bookmark' title='Permanent Link: Histórico para Navegação via JavaScript'>Histórico para Navegação via JavaScript</a></li>
<li><a href='http://juliogreff.net/estatisticas-para-navegacao-via-javascript/' rel='bookmark' title='Permanent Link: Estatísticas para Navegação via JavaScript'>Estatísticas para Navegação via JavaScript</a></li>
<li><a href='http://juliogreff.net/jquery-segundas-impressoes/' rel='bookmark' title='Permanent Link: jQuery &#8211; Segundas Impressões'>jQuery &#8211; Segundas Impressões</a></li>
</ul>]]></description>
			<content:encoded><![CDATA[<p>A web vai se tornando uma plataforma cada vez mais próximas das aplicações desktop que temos. Temos várias aplicações por aí para provar isso. Mas aos olhos do usuário, uma aplicação só com XHTML+CSS às vezes pode não ser tão interessante. De uns tempos pra cá, entretanto, várias bibliotecas surgiram para acabar com esse problema, e trazer interfaces de usuários realmente interessantes. Preparado para algo fora de série?</p>
<p>O número dessas bibliotecas é incontável, algumas mais simples, outras mais complexas, outras mais famosas, algumas nem tanto. Fiz uma breve pesquisa, e trouxe as mais conhecidas (e algumas nem tanto) para quem ainda não teve a oportunidade de conhecer. Só para lembrar, hoje não vou tratar sobre o uso dessas bibliotecas, isso fica pra uma próxima oportunidade, já que a idéia é um pouco extensa.</p>
<h3>ExtJS</h3>
<p>A <a href="http://extjs.com/" title="ExtJS" rel="external">ExtJS</a> é de longe a biblioteca mais conhecida. Provavelmente você já deve ter pelo menos ouvido falar sobre, a menos que você viva na Sibéria. Também acredito que deva ser uma das mais antigas, e por isso uma das mais completas também.</p>
<p class="center"><img src="http://juliogreff.net/wp-uploads/extjs.png" alt="ExtJS" title="ExtJS" /></p>
<p>Seu <a href="http://extjs.com/deploy/dev/examples/samples.html" title="ExtJS - Demos and Samples" rel="external">visual é espetacular</a>, mas tem seu preço: ela é muito lenta. Todos os efeitos de transparência, os drag &#8216;n&#8217; drops, tudo isso exige muito do pobre navegador. Pense bem antes de escolher onde usá-la, faça somente se for necessário, nunca para simples &#8220;enfeites&#8221;. Lenta, mas uma obra de arte.</p>
<p>E os desenvolvedores <abbr title="Adobe Integrated Runtime">AIR</abbr> não precisam ficar tristes: há até um <a href="http://extjs.com/blog/2008/02/24/tasks2/" title="Simple Tasks - AIR Application" rel="external">demo</a> do bichinho em funcionamento. Ainda não tive muito tempo com o AIR, mas acredito que a questão da velocidade não seja tão crítica quanto em um navegador, quem puder falar sobre, agradeço.</p>
<h3>Yahoo User Interface</h3>
<p class="left"><img src="http://juliogreff.net/wp-uploads/yui.png" alt="Yahoo User Interface" title="Yahoo User Interface" /></p>
<p>A <a href="http://developer.yahoo.com/yui/" title="Yahoo User Interface" rel="external">Yahoo User Interface</a>, ou YUI, deve ser a primeira user interface a se popularizar. Foi a base do nascimento da ExtJS. Tem lá seus defeitos, como o prefixo YUI para todos os métodos, mas tem um poder imenso. Me parece ser bem mais leve que a Ext, e usa gráficos bem mais simples também.</p>
<p>A documentação é um dos pontos fortes. Mantida pela comunidade de desenvolvedores do Yahoo, você nunca estará sozinho. Apesar disso, achei o site um pouco confuso para encontrar alguma coisa, principalmente os demos. Mas o material está lá, e há muito&#8230;</p>
<h3>MochaUI</h3>
<p>Ainda beta, a <a href="http://mochaui.com/" rel="external" title="MochaUI">MochaUI</a> seria a minha preferida. Adivinhem por quê? Sim, baseada na <a href="http://mootools.net/" title="Mootools Library" rel="external">Mootools</a>&#8230; A <a href="http://mochaui.com/demo/" title="MochaUI - Demo" rel="external">demonstração</a> realmente me deixou impressionado, talvez tenha sido o relógio.</p>
<p class="center"><img src="http://juliogreff.net/wp-uploads/mochaui.png" title="MochaUI" alt="MochaUI" /></p>
<p>Aparenta ser bem leve, tanto que na demonstração você pode modificar propriedades das janelas sem travar o navegador. Usa gráficos simples, mas não menos atraentes. De longe, seria a primeira que eu escolheria para trabalhar (sim, opinião extremamente parcial). Mal posso esperar pela versão 1.0!</p>
<h3>Dijit</h3>
<p>Falando em <a href="http://dojotoolkit.org/" title="Dojo Toolkit" rel="external">Dojo</a>, nem é preciso dizer muito. O framework mais abrangente que conheço também conta com sua interface de usuário, o <a href="http://dojotoolkit.org/projects/dijit" title="Dijit" rel="external">Dijit</a>. Não consegui encontrar demonstrações no site, mas as imagens mostram algo realmente promissor.</p>
<p class="center"><img src="http://juliogreff.net/wp-uploads/dijit.gif" alt="Dijit" title="Dijit" /></p>
<p>Lendo a descrição do projeto, você verá que o Dijit não é <em>apenas</em> uma simples interface de usuário. É extremamente customizável, extensível, acessível e localizável. O que isso significa? Bem, dê asas à imaginação, o céu é o limite&#8230;</p>
<h3>jQuery UI</h3>
<p>O <a href="http://ui.jquery.com/" title="jQuery UI" rel="external">jQuery UI</a>, bem jovem ainda, também é espetacular. Baseado na brilhante <a href="http://jquery.com/" rel="external" title="jQuery">jQuery</a>, tem tudo para deixar qualquer um de boca aberta. A <a href="http://ui.jquery.com/repository/real-world/effects/" title="jQuery UI Effects" rel="external">demonstração de efeitos</a>, por exemplo, me impressionou muito. A própria tela de demonstrações é uma obra de arte.</p>
<p class="center"><img src="http://juliogreff.net/wp-uploads/jqueryui.png" title="jQuery UI" alt="jQuery UI" /></p>
<p>Apesar de baseada no jQuery, achei a biblioteca ligeiramente lenta. Talvez tenha sido impressão, mas não esperava isso de jQuery. Entretanto, pela sua idade, é muito madura, muito poderosa. Se jQuery não havia <a href="http://juliogreff.net/jquery-segundas-impressões/" title="jQuery - Segundas Impressões">me chamado atenção</a> ainda&#8230;</p>
<h3>Prototype UI</h3>
<p class="center"><img src="http://juliogreff.net/wp-uploads/prototypeui.png" title="Prototype UI" alt="Prototype UI" /></p>
<p>Até então desconhecido pra mim, o release candidate <a href="http://www.prototype-ui.com/" title="Prototype UI" rel="external">Prototype UI</a> não conseguiu me chamar a atenção. Não por ser baseado em <a href="http://www.prototypejs.org/" title="Prototype" rel="external">Prototype</a> e <a href="http://script.aculo.us/" title="Scriptaculous" rel="external">Scriptaculous</a> (o que já considero um ponto contra), nem por usar um tema do Mac, mas por parecer muito prematura. Os demos apresentados são bonitinhos, mas um tanto &#8220;crus&#8221;. Prefiro não dar minha opinião, vai que o negócio vire um Ext-killer?</p>
<h3>SproutCore</h3>
<p class="center"><img src="http://juliogreff.net/wp-uploads/sproutcore.png" title="SproutCore" alt="SproutCore" /></p>
<p>O <a href="http://www.sproutcore.com/" title="SproutCore" rel="external">SproutCore</a>, iniciativa da Apple, tem uma proposta um tanto &#8220;utópica&#8221;, pelo que entendi é trazer o Cocoa para a web. As demonstrações são interessantes, mas o pobre navegador sofreu as conseqüências. Esse negócio consegue ser mais pesado que a própria Ext! Além disso, vi mais opiniões <a href="http://www.pixelbox.net/2008/06/17/sprout-core/" title="SproutCore (Pixelbox)" rel="external">negativas</a> do que positivas&#8230;</p>
<h3>UIZE</h3>
<p class="center"><img src="http://juliogreff.net/wp-uploads/uize.png" title="UIZE" alt="UIZE" /></p>
<p>O <a href="http://www.uize.com/" title="UIZE" rel="external">UIZE</a> (pronuncia-se &#8220;you eyes&#8221;) é outro que nunca havia sido apresentado a mim. Concordo com o pessoal do <a href="http://ajaxian.com/archives/uize-javascript-ui-toolkit" title="UIZE: JavaScript UI Toolkit" rel="external">Ajaxian</a>: são os efeitos mais legais que já vi. Apesar disso, a biblioteca ainda necessita muito mais trabalho, já que tem poucos recursos (poucos, mas legais).</p>
<p>Não tive a oportunidade de trabalhar por algum tempo com nenhuma dessas bibliotecas, e nem falar muito sobre as quais tenho mais experiência. Somente uma breve opinião sobre cada uma. Caso tenha esquecido de alguma, por favor, cite-a nos comentários, terei prazer em falar um pouquinho. Só uma precaução: cuidado onde você irá usar tudo isso&#8230; Existem aplicações e aplicações. Até mais!</p>


<h3>Posts Relacionados</h3><ul><li><a href='http://juliogreff.net/mootools-vs-jquery/' rel='bookmark' title='Permanent Link: Mootools vs. jQuery'>Mootools vs. jQuery</a></li>
<li><a href='http://juliogreff.net/estendendo-o-javascript/' rel='bookmark' title='Permanent Link: Estendendo o JavaScript'>Estendendo o JavaScript</a></li>
<li><a href='http://juliogreff.net/historico-para-navegacao-via-javascript/' rel='bookmark' title='Permanent Link: Histórico para Navegação via JavaScript'>Histórico para Navegação via JavaScript</a></li>
<li><a href='http://juliogreff.net/estatisticas-para-navegacao-via-javascript/' rel='bookmark' title='Permanent Link: Estatísticas para Navegação via JavaScript'>Estatísticas para Navegação via JavaScript</a></li>
<li><a href='http://juliogreff.net/jquery-segundas-impressoes/' rel='bookmark' title='Permanent Link: jQuery &#8211; Segundas Impressões'>jQuery &#8211; Segundas Impressões</a></li>
</ul>]]></content:encoded>
			<wfw:commentRss>http://juliogreff.net/interfaces-de-usuario-com-javascript/feed/</wfw:commentRss>
		<slash:comments>6</slash:comments>
		</item>
		<item>
		<title>Mootools vs. jQuery</title>
		<link>http://juliogreff.net/mootools-vs-jquery/</link>
		<comments>http://juliogreff.net/mootools-vs-jquery/#comments</comments>
		<pubDate>Mon, 18 Aug 2008 11:00:27 +0000</pubDate>
		<dc:creator>Julio Greff</dc:creator>
				<category><![CDATA[JavaScript]]></category>
		<category><![CDATA[bibliotecas]]></category>
		<category><![CDATA[jquery]]></category>
		<category><![CDATA[mootools]]></category>

		<guid isPermaLink="false">http://juliogreff.blog.br/?p=176</guid>
		<description><![CDATA[A batalha final: Mootools versus jQuery. Quem será o vencedor dessa sangrenta batalha? Tudo bem, sem violência então. Como mais novo usuário de jQuery e ainda usuário de Mootools, tive a idéia de fazer apenas uma breve comparação com as duas bibliotecas, nada de luta&#8230; Antes de tudo, nem pensem os usuários de Mootools que [...]

<h3>Posts Relacionados</h3><ul><li><a href='http://juliogreff.net/jquery-segundas-impressoes/' rel='bookmark' title='Permanent Link: jQuery &#8211; Segundas Impressões'>jQuery &#8211; Segundas Impressões</a></li>
<li><a href='http://juliogreff.net/lancada-a-mootools-12/' rel='bookmark' title='Permanent Link: Lançada a Mootools 1.2'>Lançada a Mootools 1.2</a></li>
<li><a href='http://juliogreff.net/ajax-com-a-mootools/' rel='bookmark' title='Permanent Link: Ajax com a Mootools'>Ajax com a Mootools</a></li>
<li><a href='http://juliogreff.net/mootools-eventos/' rel='bookmark' title='Permanent Link: Mootools &#8211; Eventos'>Mootools &#8211; Eventos</a></li>
<li><a href='http://juliogreff.net/mootools-chain/' rel='bookmark' title='Permanent Link: Mootools &#8211; Chain'>Mootools &#8211; Chain</a></li>
</ul>]]></description>
			<content:encoded><![CDATA[<p>A batalha final: <a href="http://mootools.net/" title="Mootools Library" rel="external">Mootools</a> versus <a href="http://jquery.com/" title="jQuery - Write Less, Do More" rel="external">jQuery</a>. Quem será o vencedor dessa sangrenta batalha? Tudo bem, sem violência então. Como <a href="http://juliogreff.net/jquery-segundas-impressoes/" title="jQuery - Segundas Impressões">mais novo usuário de jQuery</a> e ainda usuário de Mootools, tive a idéia de fazer apenas uma breve comparação com as duas bibliotecas, nada de luta&#8230;</p>
<p>Antes de tudo, nem pensem os usuários de Mootools que sou um traidor, um subversor, nem os usuários de jQuery achem que sou um <a href="http://jquerybrasil.com/" title="Comunidade jQuery Brasil" rel="external">&#8220;fiel convertido&#8221;</a> e abandonarei a Mootools para todo o sempre. Ambos dois lados de acordo e em paz, vamos à comparação.</p>
<h3>Propósito</h3>
<p>A primeira coisa que me fez dar uma segunda chance ao jQuery foi minha maturidade adquirida de uns tempos pra cá. Pude perceber que jQuery e Mootools têm propósitos diferentes. Pode-se usá-las para a mesma coisa, mas mais código terá que ser escrito.</p>
<p>A Mootools é uma biblioteca bem mais complexa e mais completa. Seu escopo é bem maior, e permite muito mais coisas. Algumas dessas coisas são a criação de classes, vários métodos para os tipos nativos da linguagem (funções para Strings, Números, Arrays), JSON, cookies, e tudo o mais que você puder imaginar através de plugins. É bem mais voltada a &#8220;programação de verdade&#8221;, ou seja, trabalhar mais com a linguagem e processamento do que seu resultado no documento.</p>
<p>A jQuery tem um escopo muito mais fechado: <abbr title="Document Object Model">DOM</abbr>. Criação e edição de objetos, seletores muito poderosos e simples, baseados em CSS e XPath e manipulação de eventos. Tudo isso integrado dentro de uma mesma função. Indo um pouco mais além, a biblioteca também inclui a criação de efeitos básicos e requisições Ajax. Ainda dentro do cifrão bombado.</p>
<h3>DOM</h3>
<p>Tanto Mootools quanto jQuery lutam nesse campo: DOM. Ambas também possuem a mesma função $, que vem me confundindo muito quando trabalho com uma ou outra biblioteca. Na Mootools, somente IDs. no jQuery, qualquer seletor CSS3 ou XPath. Não que a Mootools não tenha todos os seletores que jQuery, mas em uma função diferente: $$. Particularmente gostei separação, mas a versatilidade da jQuery absolutamente não me incomoda. Nessa parte, pra mim é um empate.</p>
<p>Ainda não tive a oportunidade de inspecionar o código da jQuery, mas posso dizer que o John Resig é um gênio: além de recuperar elementos do documento, o $ ainda os cria. E não através da criação manual de elementos e nós de texto. Você digita o HTML, e a função os cria sozinha. Adeus innerHTML&#8230; Na Mootools? Bem, acho melhor pular essa parte, vocês já devem ter percebido&#8230; jQuery na cabeça.</p>
<p>Quanto às outras funções, como definição e recuperação de atributos, ambas bibliotecas não deixam a desejar. A jQuery, entretanto, tem o diferencial de usar a mesma função para definição de uma ou várias propriedades, além de recuperá-las. Na Mootools, temos o <code>get</code> e <code>set</code>. Pra mim não faz diferença alguma em termos de desenvolvimento, ambas são intuitivas. Empate novamente.</p>
<p>No final das contas, jQuery é excepcional em tarefas de DOM, e supera, e muito, a Mootools, até por ser seu &#8220;habitat natural&#8221;.</p>
<h3>Ajax</h3>
<p>Ajax é outra frente de batalha em que as duas bibliotecas se enfrentam. jQuery conta com métodos extremamente simples para a tarefa, muito bons para requisições simples em aplicações pouco exigentes em relação a requisições assíncronas. Já a Mootools conta com uma classe bem mais trabalhada, mais extensa e mais flexível, principalmente para eventos.</p>
<p>Mesmo trabalhando com, as duas bibliotecas não o fazem para o mesmo propósito na minha opinião. A jQuery me parece melhor para requisições simples: enviar a requisição e fazer alguma coisa com a resposta. Já a Mootools trabalha com os aspectos mais &#8220;sórdidos&#8221;, como as mudanças de estado, headers, enfim. Até prefiro não falar muito sobre jQuery aqui pois não tive muito tempo com Ajax, posso ainda não ter visto algumas funcionalidades.</p>
<h3>Efeitos</h3>
<p>Existe algo que deixe uma aplicação mais interessante do que coisas se mexendo? Eu acho que não, mas esse não é o caso. Na jQuery, temos poucos efeitos built-in, mas me parece ser bem extensível. Já a Mootools tem uma gama enorme de transições, e podemos escolher qualquer propriedade do CSS para animar, e o melhor: ainda contamos com uma maneira muito fácil de criar novas transições. Mas a Mootools, principalmente nessa nova versão, peca em manter esses efeitos fáceis de aplicar. No jQuery, só um <code>fadeIn</code> ou <code>fadeOut</code> e presto, temos um efeito. No entanto, por mais chato que seja, ainda fico com a Mootools&#8230;</p>
<h3>Plugins</h3>
<p>Quando só a biblioteca sozinha não dá conta, hora de chamar os plugins. Ambas bibliotecas são extremamente extensíveis, cada uma a sua maneira. Na Mootools através da extensão das classes, no jQuery através de um &#8220;mecanismo&#8221; muito interessante, que &#8220;gruda&#8221; suas funções na função jQuery.</p>
<p>Mesmo sendo um fã da <a href="http://juliogreff.net/javascript-orientado-a-objetos-parte-1/" title="JavaScript Orientado a Objetos - Parte 1">programação orientada a objetos</a> e da maneira como a Mootools o usa, gostei muito mais da maneira como o jQuery faz a inclusão de plugins. Eles realmente passam a fazer parte da biblioteca. Vitória do jQuery, embora no final das contas não faça diferença alguma&#8230;</p>
<h3>Facilidade de Uso</h3>
<p>Nenhuma das bibliotecas tem um uso complicado. Além disso, ambas tem um foco diferente.</p>
<p>Talvez você já tenha notado, mas a maioria dos designers e programadores JavaScript menos experientes preferem jQuery. Não é à toa, ela é extremamente simples de ser usada. Nunca ouviu dizer que <a href="http://www.tableless.com.br/jquery-e-bom-para-designers" title="jQuery é bom para designers" rel="external">jQuery é para designers</a>? Isso também não significa que usuários mais experientes ou <a href="http://clientside.com.br/eu-me-rendo-jquery-e-legal-para-caramba-mesmo/" title="Eu me rendo: jQuery é legal pra caramba mesmo" rel="external">experts na linguagem</a> não irão gostar ou conseguir trabalhar.</p>
<p>Já a Mootools, como diz o <a href="http://mootools.net/" title="Mootools Library" rel="external">próprio site</a>, é direcionada a usuários intermediários ou avançados. À primeira vista ela é realmente mais complicada, sem dúvida. Talvez por isso não chame tanto a atenção quanto jQuery.</p>
<h3>E o vencedor é&#8230;</h3>
<p>Como disse logo no início do texto, jQuery e Mootools são bibliotecas diferentes, servindo para propósitos diferentes. Não é possível compará-las em sua totalidade, por isso não falei sobre muitos recursos que a Mootools oferece e jQuery não tem (built-in, é claro). jQuery é para DOM, Mootools é para facilitar sua programação. Já imaginou <a href="http://juliogreff.net/lancada-a-mootools-12/#comment-17351">ambas bibliotecas juntas</a>? Enfim, tenha bom senso e saiba utilizar as bibliotecas onde elas se dão bem, e não seja cabeça-dura como eu era tentando usar a Mootools em qualquer situação&#8230;</p>


<h3>Posts Relacionados</h3><ul><li><a href='http://juliogreff.net/jquery-segundas-impressoes/' rel='bookmark' title='Permanent Link: jQuery &#8211; Segundas Impressões'>jQuery &#8211; Segundas Impressões</a></li>
<li><a href='http://juliogreff.net/lancada-a-mootools-12/' rel='bookmark' title='Permanent Link: Lançada a Mootools 1.2'>Lançada a Mootools 1.2</a></li>
<li><a href='http://juliogreff.net/ajax-com-a-mootools/' rel='bookmark' title='Permanent Link: Ajax com a Mootools'>Ajax com a Mootools</a></li>
<li><a href='http://juliogreff.net/mootools-eventos/' rel='bookmark' title='Permanent Link: Mootools &#8211; Eventos'>Mootools &#8211; Eventos</a></li>
<li><a href='http://juliogreff.net/mootools-chain/' rel='bookmark' title='Permanent Link: Mootools &#8211; Chain'>Mootools &#8211; Chain</a></li>
</ul>]]></content:encoded>
			<wfw:commentRss>http://juliogreff.net/mootools-vs-jquery/feed/</wfw:commentRss>
		<slash:comments>20</slash:comments>
		</item>
		<item>
		<title>jQuery &#8211; Segundas Impressões</title>
		<link>http://juliogreff.net/jquery-segundas-impressoes/</link>
		<comments>http://juliogreff.net/jquery-segundas-impressoes/#comments</comments>
		<pubDate>Mon, 11 Aug 2008 11:00:10 +0000</pubDate>
		<dc:creator>Julio Greff</dc:creator>
				<category><![CDATA[JavaScript]]></category>
		<category><![CDATA[bibliotecas]]></category>
		<category><![CDATA[jquery]]></category>

		<guid isPermaLink="false">http://juliogreff.blog.br/?p=171</guid>
		<description><![CDATA[Por algum motivo de natureza desconhecida, nunca gostei muito de jQuery. Talvez eu não tenha gostado muito do $ pau-pra-toda-obra, ou então da excessiva facilidade que a biblioteca propõe. Por alguma outra razão também desconhecida, há alguns dias atrás resolvi dar uma segunda olhada na biblioteca-prodígio. Se tem tanta gente usando, algo de bom deve [...]

<h3>Posts Relacionados</h3><ul><li><a href='http://juliogreff.net/mootools-vs-jquery/' rel='bookmark' title='Permanent Link: Mootools vs. jQuery'>Mootools vs. jQuery</a></li>
<li><a href='http://juliogreff.net/interfaces-de-usuario-com-javascript/' rel='bookmark' title='Permanent Link: Interfaces de Usuário com JavaScript'>Interfaces de Usuário com JavaScript</a></li>
<li><a href='http://juliogreff.net/ajax-com-a-mootools/' rel='bookmark' title='Permanent Link: Ajax com a Mootools'>Ajax com a Mootools</a></li>
<li><a href='http://juliogreff.net/escolhendo-o-framework-certo/' rel='bookmark' title='Permanent Link: Escolhendo o Framework Certo'>Escolhendo o Framework Certo</a></li>
<li><a href='http://juliogreff.net/lancada-a-mootools-12/' rel='bookmark' title='Permanent Link: Lançada a Mootools 1.2'>Lançada a Mootools 1.2</a></li>
</ul>]]></description>
			<content:encoded><![CDATA[<p class="left"><img src="http://juliogreff.net/wp-uploads/jquery.png" alt="jQuery - Write Less, Do More" title="jQuery - Write Less, Do More" /></p>
<p>Por algum motivo de natureza desconhecida, nunca gostei muito de <a href="http://jquery.com" title="jQuery - Write Less, Do More" rel="external">jQuery</a>. Talvez eu não tenha gostado muito do $ pau-pra-toda-obra, ou então da excessiva facilidade que a biblioteca propõe. Por alguma outra razão também desconhecida, há alguns dias atrás resolvi dar uma segunda olhada na biblioteca-prodígio. Se tem tanta gente usando, algo de bom deve ter.</p>
<h3>Durante os Testes</h3>
<p>Depois alguns minutos testando a biblioteca direto no Firebug, tive a mesma impressão do que na última vez em que a usei: cada função, cada método faz no mínimo umas três coisas diferentes. Definir um atributo, recuperar seu valor, definir vários atributos ao mesmo tempo e ainda pode servir um cafezinho. Talvez esse tenha sido um dos motivos para me afastar da biblioteca. A diferença é que de uns tempos pra cá venho aumentando bastante minha maturidade na programação, e vi que esse conceito pode servir muito bem. Ponto pro jQuery.</p>
<p>Outra característica que não me agradou muito na primeira experiência com jQuery é o retorno da função <code>$</code>: ela sempre retorna um objeto jQuery, e não o objeto DOM que eu escolhi. Isso, na época, me incomodou muito. E se, na pressa, eu quiser jogar um <code>innerHTML</code> e não quiser me preocupar com criar e injetar nós? Mais uma estupidez minha, o método <code>html</code> cuida de tudo isso, e nunca mais vou precisar me preocupar em criar nós&#8230; Além do mais, acabei descobrindo que não estender objetos nativos é bem melhor em questões de performance. Mais um ponto pro cifrão polivalente.</p>
<h3>Durante a Produção</h3>
<p>Hora de passar para a prática. Como qualquer outra nova ferramenta, é complicado usar jQuery quando se está acostumado à <a href="http://mootools.net/" title="Mootools Library" rel="external">Mootools</a>. Estou me atrapalhando bastante, principalmente na hora de usar os seletores. Já cansei de usar <code>$$</code>, esquecer o # antes de IDs, trocar nomes de métodos, enfim. Tudo normal, eu pego o jeito&#8230;</p>
<p>Esquecendo a questão da produtividade em período de adaptação, fiquei bastante satisfeito com a biblioteca. No que ela se propõe a fazer, é simplesmente fenomenal, algo fora de série. Versátil, simples e poderosa. Gostei muito dos métodos relacionados a Ajax que, para qualquer requisição simples, são úteis e otimizados ao extremo em termos de código.</p>
<h3>E a escolha?</h3>
<p>Gostei de jQuery, muito. Acredite, se você nunca usou, não sabe o que está perdendo, e se já usou e não gostou antes de testar mais aprofundadamente, não seja cabeça-dura como eu e dê outra chance. <a href="http://ejohn.org/" title="John Resig" rel="external">John Resig</a>, o criador da jQuery, com certeza sabia o que estava fazendo, até porque ele é o cara!</p>
<p>Mas e a Mootools, onde fica nessa história? Não vou abandoná-la, ainda é minha biblioteca preferida. Ela é imbatível em características que o jQuery não tem. Ambos servem para propósitos diferentes. Não vou &#8220;escolher&#8221; alguma das duas, o ideal é unir o potencial de ambas, não sou xiita.</p>
<p>Essa experiência serviu para me mostrar que uma ferramenta não pode resolver <strong>todos</strong> os seus problemas de maneira eficiente, mas podemos unir várias ferramentas para resolver vários problemas da melhor maneira possível. Aguardem os próximos capítulos dessa história&#8230;</p>


<h3>Posts Relacionados</h3><ul><li><a href='http://juliogreff.net/mootools-vs-jquery/' rel='bookmark' title='Permanent Link: Mootools vs. jQuery'>Mootools vs. jQuery</a></li>
<li><a href='http://juliogreff.net/interfaces-de-usuario-com-javascript/' rel='bookmark' title='Permanent Link: Interfaces de Usuário com JavaScript'>Interfaces de Usuário com JavaScript</a></li>
<li><a href='http://juliogreff.net/ajax-com-a-mootools/' rel='bookmark' title='Permanent Link: Ajax com a Mootools'>Ajax com a Mootools</a></li>
<li><a href='http://juliogreff.net/escolhendo-o-framework-certo/' rel='bookmark' title='Permanent Link: Escolhendo o Framework Certo'>Escolhendo o Framework Certo</a></li>
<li><a href='http://juliogreff.net/lancada-a-mootools-12/' rel='bookmark' title='Permanent Link: Lançada a Mootools 1.2'>Lançada a Mootools 1.2</a></li>
</ul>]]></content:encoded>
			<wfw:commentRss>http://juliogreff.net/jquery-segundas-impressoes/feed/</wfw:commentRss>
		<slash:comments>16</slash:comments>
		</item>
	</channel>
</rss>

