|
|
|
||||||||||||||||||||||
|
|||||||||||||||||||||||
|
|||||||||||||||||||||||
Parceiros - CSS para Web Design - S.O.S Designers - Slackware-Brasil - Crie seu Web site - Oficina da Net |
Link aleatório JavascriptCriamos um link que nos leva a qualquer URL aleatoriamente, entre várias possibilidades. Vamos criar um efeito típico em páginas web que consiste em um link que nos levará a um site escolhido de forma aleatória. Para termos um idéia exata podemos ver o exemplo em funcionamento.
Para isso vamos utilizar Javascript. Embora por algumas razões não seja a melhor linguagem para fazer este exercício, sim que vai ser extremamente simples e acreditamos que também será instrutivo para os leitores. Para começar, vamos criar um array com os diferentes sites para onde poderia nos conduzir nosso link. Temos que definir este array, logicamente, dentro de um bloco <script> na própria página web. A razão pela qual Javascript não é a melhor linguagem para este exercício é justamente esta, que temos que escrever na página todos os possíveis endereços e um usuário avançado poderia ler o código da página e encontrar todas as opções escritas no array. Esa declaração do array seria algo parecido a isso: var enderecos = new Array("http://www.terra.com","http://www.google.com","http://www.yahoo.com") Como pode ser visto, na mesma linha na qual se declara o array se introduzem os valores de cada um de seus campos, utilizando o método rápido de declaração e de preenchimento de arrays em Javascript. Quanto mais valores escrevermos, mais aleatório será o exercício, podendo colocar mais links sem ter que editar o resto do código do programa. Em nosso exemplo completo temos uma lista muito maior de links. Continuamos colocando o link que se apresentará como "Link Aleatório", que nos levará a um site aleatório, dentro das possibilidades. <a href="javascript:linkAleatorio()">Link Aleatorio</a> Como vemos, o link se encarrega de chamar a uma função que será a que vai extrair uma URL do array anterior e nos transferir a este lugar. A função terá esta forma: function linkAleatorio(){ aleat = Math.random() * enderecos.length aleat = Math.floor(aleat) window.location=enderecos[aleat] } Como se pode ver, o primeiro que faz a função é obter um valor aleatório entre 0 e "enderecos.length", que é o número de URLs de nosso array. Se mudarmos o número de URLs do array este script continuará funcionando perfeitamente, porque os limites se extraem diretamente da propriedade length do array que contém os endereços. Para obter esse número aleatório se utiliza o método random da classe Math, que devolve um número entre 0 e 1. Ao multiplica-lo pelo número de posições do array obtemos um número entre 0 e o número de posições do array. Porém este número está em um número flutuante, ou seja, é um número decimal, que não nos serve como índice de um array. Por isso lhe aplicamos o método floor, também do objeto Math, para obter a parte inteira deste número. Por último se atualiza a propriedade location do objeto window com o valor do array na posição aleatória, o que faz com que o navegador se dirija à página aleatória, dentro das distintas possibilidades. Exemplo completo Para ver de maneira global este exercício, transcrevemos aqui todo o código utilizado. <html> <head> <title>Link Aleatorio</title> <script> var enderecos = new Array("http://www.terra.com.br", "http://www.google.com.br", "http://jbonline.terra.com.br", "http://www.lycos.com", "http://br.yahoo.com", "http://www.altavista.com", "http://www.hotbot.com", "http://www.buscopio.com", "http://oglobo.globo.com", "http://www.excite.com", "http://br.cade.yahoo.com", "http://www.mercadolivre.com.br", "http://br.weather.com", "http://www.buscape.com.br", "http://www.msn.com", "http://www.astrolabio.net") function linkAleatorio(){ aleat = Math.random() * enderecos.length aleat = Math.floor(aleat) window.location=enderecos[aleat] } </script> </head> <body> <a href="javascript:linkAleatorio()">LinkAleatorio</a> </body> </html> Se quiser ver o exemplo em funcionamento, clique aqui.
Autoria e outras referências sobre este artigo Dentro deste artigo: + 1 manual relacionado + 2 Categorias relacionadas + 2 Comentários sem rever
Manuais relacionados com este artigo Dentro de Workshop de Javascript Seguinte: Geração de números aleatórios Javascript Anterior: Exemplo de funcionamento de Date Categorias relacionadas Através das categorias do nosso diretório podem ser encontrados outros tipos de recursos relacionados com este artigo: + Entrar em Javascript+ Entrar em Scripts em Javascript Comentário sem rever
|
| Sobre nós | Copyright | Anuncie | Entrar em contato | <criarweb> |