Docsity
Docsity

Prepare-se para as provas
Prepare-se para as provas

Estude fácil! Tem muito documento disponível na Docsity


Ganhe pontos para baixar
Ganhe pontos para baixar

Ganhe pontos ajudando outros esrudantes ou compre um plano Premium


Guias e Dicas
Guias e Dicas

Conceitos básicos de programação com foco em JavaScript, Notas de estudo de Linguagem de Programação

Este documento fornece uma visão geral dos conceitos básicos de programação, com um foco particular no javascript. São abordados tópicos como variáveis, estruturas de controle, funções, objetos e eventos, além de fornecer exemplos de código para ilustrar cada conceito. Além disso, são apresentados conceitos específicos do javascript, como a criação de objetos e a manipulação do dom.

Tipologia: Notas de estudo

Antes de 2010

Compartilhado em 21/10/2008

michely-silva-8
michely-silva-8 🇧🇷

4

(1)

2 documentos

1 / 21

Documentos relacionados


Pré-visualização parcial do texto

Baixe Conceitos básicos de programação com foco em JavaScript e outras Notas de estudo em PDF para Linguagem de Programação, somente na Docsity! Introdução Operadores lógicos Operadores matemáticos Controles especiais Controles condicionais Eventos Criando variáveis Escrevendo no documento Mensagens Criando funções Funções intrinsecas Criando novas instâncias Manipulando arrays (matrízes) Manipulando strings Manipulando datas Interagindo com o usuário Usando Time e Date Abrindo novas janelas INTRODUÇÃO JavaScript é uma linguagem que permite injetar lógica em páginas escritas em HTML (HiperText Mark-up Language). As páginas HTML podem ser escritas utilizando-se editores de texto, como o NotePad, Write, etc. Porém, existem editores próprios para gerar HTML, tais como HotDog e (mais recomendado) Microsoft FrontPage. Os parágrafos de lógica do javaScript podem estar "soltos" ou atrelados a ocorrência de eventos. Os parágrafos soltos são executados na sequência em que aparecem na página (documento) e os atrelados a eventos são executados apenas quando o evento ocorre. Para inserir parágrafos de programação dentro do HTML é necessário identificar o início e o fim do set de JavaScript, da seguinte forma: <SCRIPT> Set de instruções </SCRIPT> Este procedimento pode ser adotado em qualquer local da página. Entretanto, para melhor visualização e facilidade de manutenção, recomenda-se que toda a lógica seja escrita no início do documento, através da criação de funções a serem invocadas quando se fizer necessário (normalmente atreladas a eventos). Se a lógica é escrita a partir de um determinado evento, não é necessário o uso dos comandos <SCRIPT> e </SCRIPT>. Os comandos JavaScript são sensíveis ao tipo de letra (maiúsculas e minúsculas) em sua sintaxe. Portanto, é necessário que seja obedecida a forma de escrever os comandos, de acordo com a forma apresentada ao longo deste manual. Caso seja cometido algum erro de sintaxe quando da escrita de um comando, o JavaScript interpretará, o que seria um comando, como sendo o nome de uma variável. Índice OPERADORES LÓGICOS São operadores a serem utilizados em comandos condicionais, tais como: IF , FOR e WHILE. Os comandos condicionais serão vistos mais a frente. = = Igual != Diferente > Maior >= Maior ou Igual < Menor <= Menor ou Igual && E || Ou Índice OPERADORES MATEMÁTICOS São operadores a serem utilizados em cálculos, referências de indexadores e manuseio de strings. Ao longo do manual estes operadores serão largamente utilizados, dando, assim, uma noção mais precisa do seu potencial. + adição de valor e concatenação de strings - subtração de valores * multiplicação de valores / divisão de valores % obtem o resto de uma divisão: Ex: 150 % 13 retornará 7 7 % 3 retornará 1 += concatena /adiciona ao string/valor já existente. Ou seja: x += y é o mesmo que x = x + y da mesma forma podem ser utilizados: -= , *= , /= ou %= Um contador pode ser simplificado utilizando-se : X++ ou X-- o que equivale as expressões: X = X + 1 ou X = X - 1 respectivamente. Para inverter sinal: X = -X negativo para positivo ou positivo para negativo. Índice CONTROLES ESPECIAIS \b - backspace \f - form feed \n - new line caracters \r - carriage return \t - tab characters // - Linha de comentário /*....*/ - Delimitadores para inserir um texto com mais de uma linha como comentário. Os delimitadores naturais para uma string são " ou ' . Caso seja necessário a utilização destes caracteres como parte da string, utilize \ precedendo " ou '. Ex. alert ("Cuidado com o uso de \" ou \' em uma string") Índice COMANDOS CONDICIONAIS São comandos que condicionam a execução de uma certa tarefa à veracidade ou não de uma determinada condição, ou enquanto determinada condição for verdadeira. São eles: Comando IF Isto resolve a questão da mudança de linha, porém, vai gerar uma linha em branco, entre cada linha, por se tratar de mudança de parágrafo. Caso não seja desejado a existência da linha em branco, a alternativa é utilizar o comando Html <br> que apenas muda de linha. Ex: <script> valor = 30 document.write ("<br>Minha primeira linha") document.write ("<br>Nesta linha aparecerá o resultado de : " + (10 * 10 + valor) ) </script> Índice MENSAGENS Existem três formas de comunicação com o usuário através de mensagens. Apenas Observação. alert ( mensagem ) Ex. alert ("Certifique-se de que as informações estão corretas") Mensagem que retorna confirmação de OK ou CANCELAR confirm (mensagem) Ex. if (confirm ("Algo está errado...devo continuar??")) { alert("Continuando") } else { alert("Parando") } Recebe mensagem via caixa de texto Input Receptor = prompt ("Minha mensagem", "Meu texto") Onde: Receptor é o campo que vai receber a informação digitada pelo usuário Minha mensagem é a mensagem que vai aparecer como Label da caixa de input Meu texto é um texto, opcional, que aparecerá na linha de digitação do usuário Ex. Entrada = prompt("Informe uma expressão matemática", "") Resultado = eval(Entrada) document.write("O resultado é = " + Resultado) Índice CRIANDO FUNÇÕES Uma função é um set de instruções, que só devem ser executadas quando a função for acionada. A sintaxe geral é a seguinte: function NomeFunção (Parâmetros) { Ação } Suponha uma função que tenha como objetivo informar se uma pessoa é maior ou menor de idade, recebendo como parâmetro a sua idade. function Idade (Anos) { if (Anos > 17) { alert ("Maior de Idade") } else { alert ("menor de Idade") } } Para acionar esta função, suponha uma caixa de texto, em um formulário, na qual seja informada a idade e, a cada informação, a função seja acionada. <form> <input type=text size=2 maxlength=2 name="Tempo" onchange="Idade(Tempo.value)"> </form> Observe-se que o parâmetro passado (quando ocorre o evento "onchange") foi o conteúdo da caixa de texto "Tempo" (propriedade "value") e que, na função, chamamos de "Anos". Ou seja, não existe co-relação entre o nome da variável passada e a variável de recepção na função. Apenas o conteúdo é passado. Índice FUNÇÕES INTRÍNSECAS São funções embutidas na própria linguagem. A sintaxe geral é a seguinte: Result = função (informação a ser processada) - eval = Calcula o conteúdo da string - parseInt - Transforma string em inteiro - parseFloat - Transforma string em número com ponto flutuante - date() - Retorna a data e a hora (veja o capítulo manipulando datas) ex1: Result = eval ( " (10 * 20) + 2 - 8") ex2: Result = eval (string) No primeiro exemplo Result seria igual a 194. No segundo, depende do conteúdo da string, que também pode ser o conteúdo (value) de uma caixa de texto. - Funções tipicamente Matemáticas: Math.abs(número) - retorna o valor absoluto do número (ponto flutuante) Math.ceil(número) - retorna o próximo valor inteiro maior que o número Math.floor(número) - retorna o próximo valor inteiro menor que o número Math.round(número) - retorna o valor inteiro, arredondado, do número Math.pow(base, expoente) - retorna o cálculo do exponencial Math.max(número1, número2) - retorna o maior número dos dois fornecidos Math.min(número1, número2) - retorna o menor número dos dois fornecidos Math.sqrt(número) - retorna a raiz quadrada do número Math.SQRT2 - retorna a raiz quadrada de 2 (aproximadamente 1.414) Math.SQRT_2 - retorna a raiz quadrada de 1/2 (aproximadamente 0.707) Math.sin(número) - retorna o seno de um número (anglo em radianos) Math.asin(número) - retorna o arco seno de um número (em radianos) Math.cos(número) - retorna o cosseno de um número (anglo em radianos) Math.acos(número) - retorna o arco cosseno de um número (em radianos) Math.tan(número) - retorna a tangente de um número (anglo em radianos) Math.atan(número) - retorna o arco tangente de um número (em radianos) Math.pi retorna o valor de PI (aproximadamente 3.14159) Math.log(número) - retorna o logarítmo de um número Math.E - retorna a base dos logarítmos naturais (aproximadamente 2.718) Math.LN2 - retorna o valor do logarítmo de 2 (aproximadamente 0.693) Math.LOG2E - retorna a base do logarítmo de 2 (aproximadamente 1.442) Math.LN10 retorna o valor do logarítmo de 10 (aproximadamente 2.302) Math.LOG10E - retorna a base do logarítmo de 10 (aproximadamente 0.434) Observação: Em todas as funções, quando apresentamos a expressão "(número)", na verdade queremos nos referir a um argumento que será processado pela função e que poderá ser: um número, uma variável ou o conteúdo de um objeto (propriedade value). Índice CRIANDO NOVAS INSTÂNCIAS Através do operador new podem ser criadas novas instâncias a objetos já existentes, mudando o seu conteúdo, porém, mantendo suas propriedades. A sintaxe geral é a seguinte: NovoObjeto = new ObjetoExistente (parâmetros) Ex1. MinhaData = new Date () MinhaData passou a ser um objeto tipo Date, com o mesmo conteúdo existente em Date (data e hora atual) Ex2: MinhaData = new Date(1996, 05, 27) MinhaData passou a ser um objeto tipo Date, porém, com o conteúdo de uma nova data. Ex3: Suponha a existência do seguinte objeto chamado Empresas function Empresas (Emp, Nfunc, Prod) { this.Emp = Emp this.Nfunc = Nfunc this.Prod = Prod } Podemos criar novas instâncias, usando a mesma estrutura, da seguinte forma: Elogica = new Empresas("Elogica", "120", "Serviços") Pitaco = new Empresas("Pitaco", "35", "Software") Corisco = new Empresas("Corisco", "42", "Conectividade") Assim, a variável Elogica.Nfunc terá o seu conteúdo igual a 120 Índice MANIPULANDO ARRAYS O JavaScript não tem um tipo de dado ou objeto para manipular arrays. Por isso, para trabalhar com arrays é necessário a criação de um objeto com a propriedade de criação de um array. No exemplo abaixo, criaremos um objeto tipo array de tamanho variável e com a função de "limpar" o conteúdo das variáveis cada vez que uma nova instância seja criada a partir dele. function CriaArray (n) { this.length = n for (var i = 1 ; i <= n ; i++) { this[i] = "" } } Agora podemos criar novas instâncias do objeto "CriaArray" e alimentá-los com os dados necessários. NomeDia = new CriaArray(7) NomeDia[0] = "Domingo" NomeDia[1] = "Segunda" NomeDia [2] = "Terça" NomeDia[3] = "Quarta" NomeDia[4] = "Quinta" NomeDia[5] = "Sexta" NomeDia[6] = "Sábado" A construção destes objetos é feita pela linguagem HTML (HiperText Mark-up Language). Portanto, é aconselhável que sejam criados utilizando-se ferramentas de geração de páginas HTML, como o HotDog ou, mais recomendado, FrontPage. Objeto Input TEXT É o principal objeto para entrada de dados. Suas principais propriedades são: type, size, maxlength, name e value. type=text : Especifica um campo para entrada de dados normal size : Especifica o tamanho do campo na tela. maxlength : Especifica a quantidade máxima de caracteres permitidos. name : Especifica o nome do objeto value : Armazena o conteúdo do campo. Os eventos associados a este objeto são: onchange, onblur, onfocus e onselect. Ex: <form name="TText"> <p>Entrada de Texto <input type=text size=20 maxlength=30 name="CxTexto" value="" onchange="alert ('Voce digitou ' + CxTexto.value)"> </p> </form> Objeto Input PASSWORD É o objeto para entrada de Senhas de acesso (password). Os dados digitados neste objeto são criptografados e, só são interpretados (vistos) pelo "server", por razões de segurança. Suas principais propriedades são: type, size, maxlength, name e value. type=password : Especifica um campo para entrada de senha. Os dados digitados são substituidos (na tela) por "*". size : Especifica o tamanho do campo na tela. maxlength : Especifica a quantidade máxima de caracteres permitidos. name : Especifica o nome do objeto value : Armazena o conteúdo digitado no campo. Os eventos associados a este objeto são: onchange, onblur, onfocus e onselect. Ex: <form name="TPassword"> <p>Entrada de Senha<input type=password size=10 maxlength=10 name="Senha" value=""> </p> </form> Objeto Input HIDDEN É um objeto semelhante ao input text, porém, invisível para o usuário. Este objeto deve ser utilizado para passar informações ao "server" (quando o formulário for submetido) sem que o usuário tome conhecimento. Suas propriedades são: name e value. name : Especifica o nome do objeto. value : Armazena o conteúdo do objeto Ex: <form name="THidden"> <input type=hidden size=20 maxlength=30 name="HdTexto" value="" > </form> </p> Objeto Input CHECKBOX São objetos que permitem ao usuário ligar ou desligar uma determinada opção. Suas principais propriedades são: name, value e checked. name : Especifica o nome do objeto value : Especifica o valor que será enviado ao "server" se o objeto estiver ligado (checked). Caso seja omitido, será enviado o valor default "on" . Esta propriedade também serve para ativar comandos lógicos, testando-se a condição de "checked". checked : Especifica que o objeto inicialmente estará ligado O único evento associado a este objeto é onclick. Ex: No exemplo abaixo, criaremos um objeto input.text e três objetos checkbox. O primeiro checkbox, quando ativado, transformará o texto em caracteres minúsculos. O segundo checkbox, quando ativado, transformará o texto em caracteres maiúsculos. O terceiro checkbox, quando ativado, dará um aviso do conteúdo que será recebido pelo "server" caso o formulário seja submetido para este. <SCRIPT> function AltMaiusc () { document.TCheck.Muda.value = document.TCheck.Muda.value.toUpperCase() document.TCheck.Opt1.checked = false } function AltMinusc () { document.TCheck.Muda.value = document.TCheck.Muda.value.toLowerCase() document.TCheck.Opt2.checked = false } </SCRIPT> <p> <form name="TCheck"> Muda Case <input type=text size=20 maxlength=20 name="Muda"> </p> <p> Minusculo<input type=checkbox name="Opt1" value="1" checked onclick="if (this.checked) { AltMinusc() } "> Maiusculo<input type=checkbox name="Opt2" value="2" onclick="if (this.checked) { AltMaiusc() } "> Demo valor<input type=checkbox name="Opt3" onclick="if (Opt3.checked) {alert ('Server recebera = ' + Opt3.value) } "> </p> </form> Existe ainda uma outra forma de manipular este objeto, em forma de array, que é a seguinte: form.elements[index].propriedade. Esta não é uma boa forma porque o index é único dentro de um formulário, exigindo muito cuidado quando se acrescenta ou se deleta um objeto, pois, neste caso, haverá um natural deslocamento do index, podendo comprometer a lógica. Objeto Input RADIO São objetos que permitem ao usuário a escolha de apenas uma alternativa, diante de uma série de opções. Suas principais propriedades são: name, value e checked. name : Especifica o nome do objeto. Para caracterizar uma mesma série de opções, todos os objetos desta série têm que ter o mesmo "name". value : Especifica o valor que será enviado ao "server" se o objeto estiver ligado (checked). Caso seja omitido, será enviado o valor default "on" . Esta propriedade também serve para ativar comandos lógicos, testando-se a condição de "checked". checked : Especifica que o objeto inicialmente estará ligado Para utilização deste objeto é importante o conhecimento de outras propriedades associadas: Objeto.length : Retorna a quantidade de opções existentes na lista Objeto.[index].value : retorna o texto (value) associado a cada opção Objeto.[index].checked : retorna verdadeiro ou falso O único evento associado a este objeto é onclick. Ex. No exemplo abaixo temos dois set's de objetos radio. O primeiro tem o objetivo de mudar a cor de fundo do documento atual. O segundo tem o objetivo levar informações ao "server". <p>Radio</p> <p> <input type=radio name="Rad" value="1" onclick="document.bgColor='green'"> Fundo Verde <input type=radio name="Rad" value="2" onclick="document.bgColor='blueviolet'"> Fundo Violeta <input type=radio name="Rad" value="3" onclick="document.bgColor='#FFFF00'"> Fundo Amarelo </p> Objeto Input BUTTON Este objeto tem por finalidade criar um botão ao qual se possa atrelar operações lógicas, a serem executadas quando o mesmo receber um click. Suas propriedades são: name e value. name : Especifica o nome do objeto. value : Especifica o nome que aparecerá sobre o botão O único evento associado a este objeto é onclick. Ex. <p> <form method="POST" name="TstButton"> Digite um Texto <input type=text size=30 maxlength=30 name="Teste" value=""> </p><p> Click no Botao <input type=button name="Bteste" value="Botao de teste" onclick="alert ('Voce digitou: ' + TstButton.Teste.value)"> </p> </form> Objeto Input RESET Este objeto é um botão que tem por finalidade, única, limpar os campos digitados pelo usuário, restaurando o conteúdo do formulário para os valores iniciais. É recomendável a utilização deste objeto, para facilitar o usuário a limpar suas informações, uma vez que a utilização da opção "reload" do "browser" (que seria uma forma) não perde as infromações digitadas. Suas propriedades são: name e value. name : Especifica o nome do objeto. value : Especifica o nome que aparecerá sobre o botão O único evento associado a este objeto é onclick. Ex. <p> <form method="POST" name="TesteRes"> b) Utilizamos a propriedade "value". Assim as propriedades "text" e "value" têm valores diferentes: text retornará Escolha 1 a Escolha 4 e value retornará List1 a List4. c) O parâmetro passado, quando da ocorrência do evento onblur, foi this. Esta diretiva significa que estamos passando este objeto. <script> function Vermult(Lista) { var opcoes = "" for (i = 0 ; i < Lista.length ; i++) { if (Lista.options[i].selected) { opcoes += (Lista.options[i].value + ", ") } } alert ("As opcoes escolhidas foram : " + opcoes) } </script> <p> Objeto Select2 <select name="Combo2" size=4 multiple onblur="Vermult(this)"> <option value="List1">Escolha 1 </option> <option value="List2">Escolha 2 </option> <option value="List3">Escolha 3 </option> <option value="List4">Escolha 4 </option> </select> </p> Focando um Objeto Este método permite que o cursor seja ativado em um determinado objeto (focado). Isso pode ser feito na carga do documento, a partir da ocorrência de um evento ou mesmo dentro de uma função. Observe que até agora o usuário tinha que dar um "Click" para focar o objeto desejado. De forma semelhante existe o método "Select". Este método marca o conteúdo do objeto com uma tarja roxa, permitindo ao usuário, em caso de substituição do conteúdo do campo, não ter que deletar o conteúdo anterior, pois, com este método, a deleção se dá de forma automática quando da digitação do novo conteúdo. Os métodos "Focus" e "Select" podem ser utilizados nos seguintes objetos: password, select, text e textarea No exemplo abaixo, utilizaremos o evento onload para setar o focus para o primeiro objeto do formulário e os métodos focus e select para, na rotina de crítica dos dados, focar o objeto que contiver erro de preenchimento. Ex. <body onload="document.TstFocus.Nome.focus()"> <script> DdosOk = true function Criticar() { DadosOk = false DataAtual = new Date() MesAtual = DataAtual.getMonth() + 1 AnoAtual = DataAtual.getYear() + 1900 Nome = document.TstFocus.Nome.value Mes = parseInt(document.TstFocus.Mes.value) Ano = parseInt (document.TstFocus.Ano.value) // if (Ano < 1900) {Ano = Ano + 1900 } if (Nome == "") { alert ("Informe o seu Nome, Não deixe em branco") document.TstFocus.Nome.focus() return } if (Mes < 1 || Mes > 12) { alert ("O Mês informado não é válido, informe corretamente") document.TstFocus.Mes.focus() document.TstFocus.Mes.select() return } if (Ano == AnoAtual && Mes > MesAtual) { alert ("O período informado é superior a data atual") document.TstFocus.Mes.focus() document.TstFocus.Mes.select() return } if (Ano < 1996 || Ano > AnoAtual) { alert ("O Ano informado não é válido, informe corretamente") document.TstFocus.Ano.focus() document.TstFocus.Ano.select() return } DadosOk = true } </script> <form name="TstFocus" method="POST"> <p> Informe o seu Nome <input type=text size=30 maxlength=30 name="Nome"> </p> <p> Informe o mês desejado <input type=text size=2 maxlength=2 name="Mes"> </p> <p> Informe o ano desejado <input type=text size=4 maxlength=4 name="Ano" > </p> <p> <input type=button name="Testa" value="Testar Validade" onclick="Criticar() if (DadosOk) {alert ('Todos os Dados estão Corretos') } "> </p> </form> </body> Índice USANDO TIMER e DATE É um método que permite a programação para que uma determinada ação só ocorra após o transcurso de um determinado tempo. Variável = setTimeout ("ação", tempo) Onde: Variável é uma variável apenas para controle do timer ação é a ação que se quer realizar. tempo é o tempo de espera para que a ação ocorra, em milisegundos. Obs: É importante observar que a ação só ocorrerá uma vez. Para que a ação volte a ocorrer, será necessário repetir o comando dentro da ação, obtendo-se, assim, um LOOP. Para interromper um LOOP, provocado pela forma acima, deve-se utilizar o seguinte método: clearTimeout (Variável) Onde: Variável é o nome da variável de controle do timer. Abaixo encontra-se um exemplo de um formulário que apresenta a data e hora atual, atualizando os dados a cada um segundo, tendo dois botões de rádio que tem a função de ativar e desativar a atualização dos dados. Apresenta também, fora do formulário, a data contendo dia e mês por extenso. <script> function Hoje() { ContrRelogio = setTimeout ("Hoje()", 1000) Hr = new Date() dd = Hr.getDate() mm = Hr.getMonth() + 1 aa = Hr.getYear() hh = Hr.getHours() min = Hr.getMinutes() seg = Hr.getSeconds() DataAtual = ((dd < 10) ? "0" + dd + "/" : dd + "/") DataAtual += ((mm < 10) ? "0" + mm + "/" + aa : mm + "/" + aa) HoraAtual = ((hh < 10) ? "0" + hh + ":" : hh + ":") HoraAtual += ((min < 10) ? "0" + min + ":" : min + ":") HoraAtual += ((seg < 10) ? "0" + seg : seg) document.DataHora.Data.value=DataAtual document.DataHora.Hora.value=HoraAtual } // function CriaArray (n) { this.length = n } // NomeDia = new CriaArray(7) NomeDia[0] = "Domingo" NomeDia[1] = "Segunda" NomeDia[2] = "Terça" NomeDia[3] = "Quarta" NomeDia[4] = "Quinta" NomeDia[5] = "Sexta" NomeDia[6] = "Sábado" // NomeMes = new CriaArray(12) NomeMes[0] = "Janeiro" NomeMes[1] = "Fevereiro" NomeMes[2] = "Março" NomeMes[3] = "Abril" NomeMes[4] = "Maio" NomeMes[5] = "Junho" navigator.appVersion para verificarmos a versão do browse que esta sendo utilizado document.location. para obtermos o Path da localização do arquivo Html que está correntemente em uso. No exemplo abaixo estamos, inicialmente, identificando a versão do browse.Caso seja antiga, para não escrevermos todo o caminho a cada chamada e ainda, considerando que os arquivos chamados estão no mesmo diretório da página atual, estamos obtendo o Path do arquivo atual e eliminando o nome do arquivo que está na última referencia do Path. Quando fizermos a chamada das imagens (comando src) só será necessário a concatenação do nome do arquivo chamado com a raiz do path que, no exemplo, armazenamos na variável de nome Local. <script> function Abrejanela(Opcao) { Versao = navigator.appVersion Versao = Versao.substring(0, 1) Local = "" if (Versao < 3) { Local = document.location UltLoc = Local.lastIndexOf("/") Local = Local.substring(0, UltLoc + 1) } // NovaJanela = window.open ("", "OutraJanela", "width=300,height=400") NovaJanela.document.open() NovaJanela.document.write ("<html><head><title>Nova Janela") NovaJanela.document.write ("</title></head><body bgcolor='white'>") NovaJanela.document.write ("<form>") if (Opcao == 1) { NovaJanela.document.write ("<br>Logomarca Elogica<hr><br>") NovaJanela.document.write ("<img width=200 height=200 src=" + Local + "Marcaelo.gif>") } else { NovaJanela.document.write ("<br>Recife Alto Astral<hr><br>") NovaJanela.document.write ("<img width=150 height=200 src=" + Local + "Recife.gif>") } // NovaJanela.document.write ("<br><hr><p></p></form>") NovaJanela.document.write ("<form><input type='button' name='Fecha'" + "value='Fecha Janela'" + "onclick='window.close()'>") NovaJanela.document.write ("</form></body></html>") NovaJanela.document.close() } </script> <body> <p></p> <p>Escolha a foto a ser apresentada na nova janela:</p> <form method="POST" name="Form1"> <p> <input type=radio name="Opcao" value="1" checked>Elogica <input type=radio name="Opcao" value="2">Recife </p> <p> <input type="button" name="Envia" value="Nova Janela" onclick="if (Form1.Opcao[0].checked == true) {Abrejanela(Form1.Opcao[0].value) } else {Abrejanela(Form1.Opcao[1].value) } "> </p> </form> </body>
Docsity logo



Copyright © 2024 Ladybird Srl - Via Leonardo da Vinci 16, 10126, Torino, Italy - VAT 10816460017 - All rights reserved