Você está na página 1de 13

Pgina 1 Apostila jQuery

Apostila jQuery
Contedo
1. Configurao
2. Ol jQuery
3. Me encontre: sando seletores e e!entos
4. Me a!alie: sando A"A#
5. Me ani$e: sando %feitos
6. Me ordene: sando o plugin ta&lesorter 'ordenador de ta&ela(
7. Me plugue: %scre!endo seus pr)prios plugins
8. Pr)*i$os passos
Por onde co$ear co$ a jQuery+
Este guia uma introduo biblioteca jQuery. Ter um conhecimento sobre javascript e
modelo de objeto de documento (,OM) so requisitos necessrios. Ele comea
do bsico e tenta eplicar os detalhes quando necessrio. Ele abordar um
eemplo simples al! mundo" seletores e eventos bsicos" A"A#" e#eitos e o
desenvolvimento de plugins.
Este guia no contm eemplos $prontos para clicar$. % inteno de prover apenas os
$c&digos para copiar$ um convite para que voc' mesmo #aa os testes. (opie
um eemplo" veja o que ele #a)" e modi#ique*o.
Pgina - Apostila jQuery
Configurao
+ara comear" n&s precisamos de uma c&pia da biblioteca j,uer-. %inda que a verso mais
recente possa ser encontrada neste lin./ .ttp://docs0j1uery0co$/,o2nloading3jQuery" este
guia #ornece um pacote bsico que voc' poder baiar.
0it para comear com o j,uer-/ 1aa o do2nload deste arquivo e etraia o seu conte3do. %bra o
starter.it.html e o custom.js com o seu editor pre#erido e o starterkit.html com o navegador.
4Caso j ten.a este ar1ui!o e$ seu co$putador no . necessidade de &ai*5lo0
%gora n&s temos tudo o que precisamos para iniciar o not&rio eemplo do 6Al7 $undo60
8in9s interessantes para este cap:tulo:
0it para comear
4o2nloads do j,uer-
Ol jQuery
(omo quase tudo o que #a)emos quando estamos utili)ando o jQuery l' ou manipula um modelo
de objeto de documento (456)" precisamos nos certi#icar que comeamos adicionado eventos
etc to logo o 456 esteja pronto.
+ara #a)er isso" n&s registramos o evento ready (pronto) para o documento.
7(document).read-(#unction() 8
99 #aa alguma coisa quando o 456
estiver pronto
:);
(olocar um alert nesta #uno no #a) muito sentido" pois o alert no requer que o 456 esteja
carregado. Ento vamos tentar algo mais so#isticado/ 6ostrar um alert quando clicarmos o lin..
7(document).read-(#unction()
8
7($a$).clic.(#unction()
8
alert($5l
mundo<$);
:);
:);
4essa #orma o alert ser eibido assim que voc' clicar no lin..
=amos dar uma olhada no que estamos #a)endo/ 7($a$) um seletor do j,uer-" neste caso" ele
seleciona todos os elementos a. 5 7 por si s& um alias para a $classe$ j,uer-" por outro lado o
7() constr&i um novo objeto j,uer-. % #uno clic.() que chamamos depois um mtodo do
objeto j,uer-.
Ele liga o evento clique a todos os elementos selecionados (neste caso" um 3nico elemento a) e
eecuta a #uno #ornecida quando o evento ocorre. >sto similar ao seguinte c&digo/
<a href="#" onclick="alert('Ol mundo')">ink<!a>
Pgina ; Apostila jQuery
% di#erena bem &bvia/ ?&s no precisamos escrever onclic. para todo elemento. ?&s
temos uma separao clara de estrutura (@T6A) e comportamento (BC)" assim como
separamos estrutura e #ormatao utili)ando (CC.
(om isso em mente" eploramos seletores e eventos um pouco mais a #undo.
8in9s interessantes para este cap:tulo:
Dase do j,uer-
EpressEes do j,uer-
Eventos Dsicos do j,uer-
Me encontre: sando seletores e e!entos
5 j,uer- prov' duas maneiras de selecionar elementos. % primeira utili)a uma combinao de
seletores (CC e F+ath passados como uma string para o construtor do j,uer- (e. 7($div G ul
a$)). % segunda utili)a vrios mtodos do objeto j,uer-. %mbas podem ser combinadas.
+ara testar alguns desses seletores" vamos selecionar e modi#icar a primeira lista ordenada no
nosso .it para comear.
+rimeiramente queremos selecionar a pr&pria lista. % lista tem um >4 $lista5rdenada$. ?o
javascript clssico" voc' pode selecion*la usando document.getElementD->d($lista5rdenada$).
(om o j,uer-" n&s #a)emos isso assim/
7(document).read-(#unction() 8
7
($Hlista5rdenada$).add(lass($vermelho$);
:);
5 .it para comear #ornece uma #olha de estilos com a classe $vermelho$ que simplesmente
adiciona um #undo vermelho. ?o entanto" quando voc' recarrega a pgina no seu navegador"
voc' ver que a primeira lista tem o #undo vermelho. % segunda lista permanece inalterada.
%gora vamos adicionar mais classes para os elementos #ilhos desta lista.
7(document).read-(#unction() 8
7($Hlista5rdenada G
li$).add(lass($a)ul$);
:);
>sto seleciona todos os lis #ilhos do elemento com id lista5rdenada e adiciona a classe $a)ul$.
%gora alguma coisa mais so#isticada/ ?&s queremos adicionar e remover a classe quando o
usurio passar o mouse sobre o elemento li" mas somente no 3ltimo elemento da lista.
7(document).read-(#unction() 8
7($Hlista5rdenada
li/last$).hover(#unction() 8
7(this).add(lass($verde$);
:" #unction() 8
7
(this).remove(lass($verde$);
:);
:);
Pgina < Apostila jQuery
Eistem diversos outros seletores similires sintae (CC e F+ath. 6ais eemplos e a lista de
todas as epressEes disponIveis podem ser encontrados neste lin./
http/99docs.jquer-.com94569Traversing9Celectors.
+ara todo evento onxxx disponIvel" como onclic." onchange" onsubmit" eistem um equivalente
no j,uer-. %lguns outros eventos" como read- e hover" so mtodos convenientes para algumas
tare#as.
=oc' pode encontrar uma lista completa com todos os eventos suportados no
http/99222.visualjquer-.com na seo de Events.
(om estes seletores e eventos voc' j pode #a)er muita coisa" mas tem muito mais.
7(document).read-(#unction() 8
7
($Hlista5rdenada$).#ind($li$).each(#uncti
on(i) 8
7(this).html( 7(this).html() J $
D%6< $ J i );
:);
:);
5 #ind() permite que voc' #aa uma pesquisa mais a #undo nos descendentes dos elementos j
selecionados" apesar de 7($Hlista5rdenada).#ind($li$) ser praticamente o mesmo que 7
($Hlista5rdenada li$). 5 each() #a) a iterao sobre cada elemento e permite um processamento
mais pro#undo. % maioria dos mtodos" como o add(lass()" utili)a o each() internamente. ?este
eemplo" o html() utili)ado para recuperar o teto de cada elemento li" adicionar algum teto a
ele e de#inI*lo como o teto do elemento.
Kma outra tare#a que voc' #requentemente ter que lidar chamar mtodos em elementos 456
que no so suportados pelo j,uer-. +ense em um #ormulrio que voc' gostaria de resetar
depois que enviou com sucesso via %B%F.
7(document).read-(#unction() 8
99 use isto para resetar um 3nico
#ormulrio
7($Hreset$).clic.(#unction() 8
7($H#orm$)LMN.reset();
:);
:);
Este c&digo seleciona o elemento com o >4 $#orm$ e chama o reset() no primeiro elemento
selecionado. (aso eista mais de um #orm" voc' pode #a)er dessa maneira/
7(document).read-(#unction() 8
99 use isto para resetar todos os #ormulrios
de uma s& ve)
7($Hreset$).clic.(#unction() 8
7($#orm$).each(#unction() 8
this.reset();
:);
:);
:);
>sto deve selecionar todos os #ormulrios no seu documento" #a)er a iterao sobre eles e
chamar o reset() para cada um.
Pgina = Apostila jQuery
5utro problema que voc' pode encontrar no selecionar alguns elementos. 5 j,uer- prov' o
#ilter() e o not() para isto. Enquanto o #ilter() redu) a seleo para os elementos que atendem
epresso de #iltro" o not() #a) eatamente o contrrio" removendo todos os elementos que
atendem a epresso. >magine uma lista desordenada onde voc' quer selecionar todos os
elementos li que no possuam um #ilho ul.
7(document).read-(#unction() 8
7($li$).not($LulN$).css($border$" $Op
solid blac.$);
:);
>sto seleciona todos os elementos li e remove todos os elementos da seleo que possuam um
elemento ul como #ilho. Cendo assim todos os elementos li #icaro com uma borda" com eceo
daqueles que possuam um #ilho ul. % sintae LepressoN vinda do F+ath e pode ser utili)ada
para #iltrar elementos e atributos #ilhos. Talve) voc' queira selecionar todas as Pncoras que
possuam o attributo name/
7(document).read-(#unction() 8
7
($aLQnameN$).bac.ground($Heee$);
:);
>sto adiciona uma cor de #undo para todos os elementos Pncora com o atributo name.
6ais comum que selecionar as Pncoras pelo nome" voc' pode precisar selecionar as Pncoras
pelo atributo $hre#$. >sto pode ser um problema uma ve) que os navegadores se comportam
inconsistentemente quando retornam o que eles pensam que o valor do $hre#$ . +ara selecionar
apenas uma parte do value" podemos utili)ar o seletor contm $RS$ ao invs do igual ($S$)/
7(document).read-(#unction() 8
7($aLQhre#RS9content9galler-N$).clic.(#unction() 8
99 #aa alguma coisa com todos os lin.s que apontam para algum lugar
em 9content9galler-
:);
:);
%t agora" usamos todos os seletores para selecionar os #ilhos ou #iltrar a seleo atual. Eistem
situaEes onde voc' ir precisar selecionar os anteriores ou pr&imos elementos" conhecidos
como siblings (#ilhos do mesmo pai). +ense em uma pgina de um 1%," onde todas as respostas
esto escondidas em um primeiro momento e so eibidas quando a questo clicada. 5 c&digo
do j,uer- para isso/
7(document).read-(#unction() 8
7
(TH#aqT).#ind(TddT).hide().end().#ind(TdtT).clic.(#unction
() 8
var resposta S 7(this).net();
i# (resposta.is(T/visibleT)) 8
resposta.slideKp();
: else 8
resposta.slide4o2n();
:
:);
:);
%qui estamos usando um pouco de encadeamento para redu)ir o tamanho do c&digo e ganhar
per#ormance" uma ve) que TH#aqT selecionada apenas uma 3nica ve). Ksando o end()" o
Pgina > Apostila jQuery
primeiro #ind() des#eito" assim podemos comear a procurar com o pr&imo #ind() no nosso
elemento H#aq" ao invs de procurar no #ilho dd.
(om o acionamento do evento clic." a #uno passada ao mtodo clic.()" utili)amos 7(this).net()
para encontrar o pr&imo sibling a partir do dt atual. >sto nos permite selecionar rapidamente a
resposta seguinte questo clicada.
%lm dos siblings" voc' tambm pode selecionar os elementos pais (tambm conhecidos como
ancestrais para os mais #amiliari)ados com o F+ath). Talve) voc' pode querer realar o
pargra#o que o pai do lin. que o usurio passar o mouse. Tente isso/
7(document).read-(#unction() 8
7($a$).hover(#unction() 8
7
(this).parents($p$).add(lass($realcar$);
:" #unction() 8
7
(this).parents($p$).remove(lass($realca
r$);
:);
:);
+ara todos os elementos Pncoras que o usurio passar o mouse" o pargra#o pai procurado e a
classe $realcar$ adicionada e removida.
=amos voltar um passo atrs de continuarmos/ o j,uer- #a) com que o c&digo #ique menor e
tornando*o mais #cil de ler e dar manuteno. 5 c&digo seguinte um atalho para a notao 7
(document).read-(callbac.)/
7(#unction() 8
99 c&digo a ser eecutado quando 456
est pronto
:);
%plicado ao eemplo do %l! 6undo<" #icaria
assim/
7(#unction() 8
7($a$).clic.(#unction() 8
alert($%l! 6undo<$);
:);
:);
%gora com o bsico em mos" queremos eplorar outros aspectos" comeando com o %B%F.
8in9s interessantes para este cap:tulo:
4ocumentao da %+> do j,uer-
=isual j,uer- * Kma documentao categori)ada e navegvel da %+> do j,uer-
EpressEes do j,uer-/ (CC
EpressEes do j,uer-/ F+ath
EpressEes do j,uer-/ (ustomi)adas
Eventos especiais no j,uer-
j,uer- 456 Traversing
Me a!alie: sando A"A#
Pgina ? Apostila jQuery
?esta parte n&s escreveremos uma pequena aplicao %B%F que permite que o usurio avalie
alguma coisa" assim como #eito no -outube.com.
+recisamos de um pouco de c&digo do servidor para isso. 6eu eemplo utili)a um arquivo php
que l' o parPmetro $avaliacao$ e retorna o n3mero de avaliaEes e a mdia de avaliao. 4'
uma olhada no rate.php para o c&digo server*side.
?&s no queremos que este eemplo #uncione sem %B%F" mesmo que isto seja possIvel" ento
n&s geramos a marcao necessria com o j,uer- e a adicionamos div com o >4 $avaliacao$.
7(document).read-(#unction() 8
99 gera a marcao
var rating6ar.up S L$+or #avor avalie/ $N;
#or(var iSO; i US V; iJJ) 8
rating6ar.upLrating6ar.up.lengthN S $Ua hre#STHTG$ J i
J $U9aG $;
:
99 adiciona a marcao ao container e aplica o acionador de clic.
s Pncoras
7
($Havaliacao$).append( rating6ar.up.join(TT) ).container.#ind($a$).clic.(#un
ction(e) 8
e.prevent4e#ault();
99 envia a requisio
7.post($rate.php$" 8avaliacao/ 7(this).html():"
#unction(ml) 8
99 #ormata o resultado
var resultado S L
$5brigado por avaliar" mdia atual/ $"
7($media$" ml).tet()"
$" n3mero de votos/ $"
7($contador$" ml).tet()
N;
99 saIda do resultado
7($Havaliacao$).html(resultado.join(TT));
: );
:);
:);
Este pedao de c&digo gera cinco elementos Pncoras adicionando*os ao elemento container com
o id $avaliacao$. 4epois disso" para cada Pncora no container" um observador do clic.
adicionado. ,uando a Pncora clicada" uma requisio post enviada para o rate.php com o
conte3do da Pncora como parPmetro. 5 resultado retornado como um F6A ento adicionado
ao container" substituindo as Pncoras.
Ce voc' no possui um servidor 2eb com o +@+ instalado em mos" voc' pode dar uma olhada
no eemplo on*line.
+ara ver um eemplo muito bom de um sistema de avaliao que #unciona at mesmo sem
javascript" visite so#tonic.de e clique em $0ur) be2erten<$
6ais documentao sobre os mtodos %B%F do j,uer- pode ser encontrada aqui ou no =isual
j,uer- na categoria %B%F.
Km problema muito comum encontrado quando se carrega um conte3do por %B%F o seguinte/
,uando se adiciona controladores de evento ao seu documento que deveriam ser aplicados
tambm ao conte3do carregado" voc' deve aplicar estes controladores depois que o conte3do
carregado. +ara prevenir a c&digo duplicado" voc' pode delegar a uma #uno. Eemplo/
Pgina @ Apostila jQuery
99 =amos usar o atalho
7(#unction() 8
var add(lic.@andlers S #unction() 8
7
($a.clique+ara(arregar(onteudo$).clic.(#unction() 8
7($Htarget$).load(this.hre#"
add(lic.@andlers);
:);
:;
add(lic.@andlers();
:);
%gora a #uno add(lic.@andlers aplicada uma ve) quando o 456 est pronto e depois toda
ve) que o usurio clicar um lin. com a classe clique+ara(arregar(onteudo e o conte3do tiver
terminado de ser carregado.
+or #avor observe que a #uno $add(lic.@andlers$ de#inida como uma varivel local" ao invs
de uma #uno global (como #unction add(lic.@andlers() 8...:). +rocure seguir esta prtica para
prevenir con#lito com outras variveis ou #unEes globais.
(om %B%F podemos eplorar muita coisa $Web X.M$. 6as at agora estamos devendo e#eitos
bacanas.
8in9s interessantes para este cap:tulo:
6&dulo %B%F do j,uer-
%+> do j,uer-/ (ontm descrio e eemplos para adicionar e todos os outros mtodos do
j,uer-
Thic.Do/ Km plugin para o j,uer- que o utili)a para aprimorar o #amoso lightbo
Me ani$e: sando %feitos
%nimaEes simples com o j,uer- podem ser #eitas com o sho2() e o hide()
7(document).read-(#unction() 8
7($a$).toggle(#unction() 8
7
($.algumacoisa$).hide(Tslo2T);
:" #unction() 8
7
($.algumacoisa$).sho2(T#astT);
:);
:);
=oc' pode criar qualquer combinao das animaEes com o animate() como por eemplo um
slide com #ade/
7(document).read-(#unction() 8
7($a$).toggle(#unction() 8
7
($.algumacoisa$).animate(8
height/
ThideT"
opacit-/
ThideT
:" Tslo2T);
:" #unction() 8
Pgina A Apostila jQuery
7
($.algumacoisa$).animate(8
height/
Tsho2T"
opacit-/
Tsho2T
:" Tslo2T);
:);
:);
E#eitos muito mais so#isticados podem ser #eitos com a coleo de plugins >nter#ace
(http/99inter#ace.e-econ.ro9). ?o site voc' encontrar demonstraEes e a documentao.
%lm da coleo >nter#ace" que est no topo da lista de plugins do j,uer-" eistem muitos outros.
5 pr&imo capItulo lhe mostrar como usar o plugin tablesorter.
8in9s interessantes para este cap:tulo:
6&dulo de e#eitos do j,uer-
+lugin >nter#ace
Me ordene: sando o plugin ta&lesorter
5 plugin tablesorter permite que voc' ordene as tabelas no lado do cliente. =oc' inclui o j,uer-
e o pluguin e in#orma ao pluguin quais tabelas deseja ordernar.
+ara eperimentar este eemplo" adicione esta linha ao starter.it.html (abaio da incluso do
jquer-)/
<script src="li"!j#uery.ta"lesorter.js" type="te$t!ja%ascript"><!script>
4epois de incluir o plugin" voc' poder cham*lo assim/
7
(document).read-(#unction()
8
7
($Hlarge$).tableCorter();
:);
Tente clicar nos cabealhos da tabela e veja se ela #ica ordenada em ordem ascendente no
primeiro clique e descendente no segundo.
% tabela deve utili)ar algum realce nas linhas" podemos adicion*los passando algumas opEes/
7(document).read-(#unction() 8
7($Hlarge$).tableCorter(8
stripingYo2(lass/ LToddT"TevenTN" 99 ?ome da classe a ser utili)ada para a diviso
das linhas como um arra-.
stripYo2s5nCtartKp/ true 99 4ivide as linhas quando o tableCorter iniciar.
:);
:);
Pgina 1B Apostila jQuery
Eistem mais eemplos e documentao sobre as opEes disponIveis no site do tablesorter
(222.motherrussia.pol-ester.se9jquer-*plugins9tablesorter9).
% maioria dos plugins pode ser utili)ada como este/ >nclua o arquivo do plugin e chame o mtodo
do plugin em alguns elementos" passando os parPmetros opcionais para customi)ar o plugin.
Kma lista atuali)ada dos plugins disponIveis pode ser encontrada no site do j,uer-
(222.jquer-.com9plugins).
,uando voc' utili)ar o j,uer- com mais #reqZ'ncia" voc' perceber que ser melhor empacotar
o seu pr&prio c&digo como um plugin" seja para o reuso para voc' mesmo ou para a sua
empresa" ou para compartilh*lo com a comunidade. 5 pr&imo capItulo d algumas dicas sobre
como estruturar um plugin.
8in9s interessantes para este cap:tulo:
+lugins para o j,uer-
Tablesorter +lugin
Plugue5$e: %scre!endo seus pr)prios plugins
Escrever seus pr&prios plugins para o j,uer- muito #cil. Ce voc' seguir as regras abaio" ser
#cil para outros integrarem o seu plugin tambm.
1. Encontre um nome para o seu plugin, vamos chamar o nosso exemplo "foobar".
2. Crie um arquivo chamado jquery.nomedoseuplugin!.js, ex. jquery.foobar.js
". Crie um ou mais m#todos no plugin extendendo o objeto j$uery, ex.%
&. j$uery.fn.foobar ' function() *
+. ,, fa-a alguma coisa
./
0. 1pcional% Crie um objeto com fun-2es de ajuda, ex.%
3. j$uery.foo4ar ' *
5. height% +,
6. calculate4ar ' function() * ... .,
17. chec89ependencies ' function() * ... .
};
:oc; poder< ent=o chamar essa fun-=o de ajuda pelo seu plugin%
j$uery.fn.foobar ' function() *
,, fa-a alguma coisa
j$uery.foobar.chec89ependencies(value)/
,, fa-a alguma outra coisa
./
Pgina 11 Apostila jQuery
11.1pcional% Crie configura-2es padr2es que possam ser alteradas pelo usu<rio, ex.%
12.j$uery.fn.foobar ' function(options) *
13. var settings ' *
1&. value% +,
1+. name% "pete",
10. bar% 0++
13. ./
15. if(options) *
16. j$uery.extend(settings, options)/
27. .
./
=oc' pode ento chamar o plugin sem opEes" usando as con#iguraEes padrEes/
&("...").foo"ar()'
5u com algumas opEes/
7
($...$).#oobar(8
value/
OX["
bar/ \
:);
Ce voc' lanar o seu plugin" voc' dever prover alguns eemplos e uma documentao. Eistem
diversos plugins disponIveis como &timas re#er'ncias.
%gora voc' j deve ter uma idia bsica de como escrever um plugin. =amos utili)ar este
conhecimento e escrever nosso pr&prio plugin.
Kma coisa que muita gente" tentando manipular #ormulrios com o j,uer-" pede" marcar e
desmarcar radio buttons ou chec.boes. Eles acabam com um c&digo como este/
7
($inputLQt-peSTchec.boTN$).each(#u
nction() 8
this.chec.ed S true;
99 ou" para desmarcar
this.chec.ed S #alse;
99 ou" para inverter
this.chec.ed S <
this.chec.ed;
:);
Cempre que voc' possuir um each no seu c&digo" voc' pode querer reescrever isto com um
plugin" quase sem alteraEes/
7.#n.chec. S #unction() 8
return
this.each(#unction() 8
this.chec.ed S
true;
:);
:;
Este plugin agora pode ser utili)ado/
Pgina 1- Apostila jQuery
&("input()type='check"o$'*").check()'
%gova voc' pode escrever plugins para as duas #unEes unchec.() e toggle(hec.() tambm. 6as
ao contrrio n&s estendemos nosso plugin para aceitar algumas opEes.
7.#n.chec. S #unction(modo) 8
var modo S modo ]] TonT; 99 se modo no est de#inido" use
TonT como padro
return this.each(#unction() 8
s2itch(modo) 8
case TonT/
this.chec.ed S true;
brea.;
case To##T/
this.chec.ed S #alse;
brea.;
case TtoggleT/
this.chec.ed S <this.chec.ed;
brea.;
:
:);
:;
4e#inindo um valor padro para as opEes" permite que o usurio omita a opo ou passe $on$"
$o##$" e $toggle$" e./
&("input()type='check"o$'*").check()'
&("input()type='check"o$'*").check('on')'
&("input()type='check"o$'*").check('off')'
&("input()type='check"o$'*").check('to++le')'
(om mais de uma con#igurao opcional" este mtodo torna*se complicado" pois o usurio
dever passar valores nulos se quiser omitir o primeiro parPmetro e usar somente o segundo.
5 uso do tablesorter no 3ltimo capItulo demonstra o uso de um objeto literal tambm resolve
este problema. 5 usurio omite todos os parPmetros ou passa um objeto com um par
chave9valor para cada con#igurao que deseja sobrescrever.
(omo um eercIcio" voc' poderia tentar reescrever o c&digo do quarto capItulo como um plugin.
5 esqueleto do plugin deve ser similar a isto/
7.#n.rate6e S #unction(options) 8
var container S this; 99 ao invs de selecionar um container esttico com 7
($Hrating$)" n&s agora utili)amos o conteto do j,uer-
var settings S 8
url/ $rate.php$
99 coloque mais padrEes aqui
99 lembre*se de colocar uma vIrgula ($"$) depois de cada par" mas no depois
do 3ltimo<
:;
i#(options) 8 99 veri#ica se as opEes esto presentes antes de estender as
con#iguraEes
7.etend(settings" options);
:
99 ...
Pgina 1; Apostila jQuery
99 resto do c&digo
99 ...
return this; 99 se possIvel" retorne $this$ para no quebrar a corrente
:);
Pr)*i$os passos
Ce voc' tem interesse em desenvolver mais em javascript" voc' deve dar uma olhada numa
etenso do 1ire#o chamada 1ireDug. Ela prov' um console (&timo para substituir os alerts)" um
debugger e outras coisas 3teis para o seu desenvolvimento dirio em javascript.
Ce voc' tem problemas que no consegue resolver" idias que gostaria de compartilhar ou
apenas necessidade de epressar sua opinio sobre o j,uer-" sinta*se vontade para postar na
lista de discusso do j,uer- (222.jquer-.com9discuss).

Você também pode gostar