Jump to content
cviniciussdias

Por que ações executadas dentro de loops são realizadas depois das dem

Recommended Posts

Por que, se eu adiciono um código dentro de um loop (for, por exemplo), as ações dentro dele são executadas após o que está fora?

Por exemplo, o seguinte script:

(function () {
    var i, teste = document.getElementById("teste");
    teste.innerHTML = "<ul>";
    for (i = 0; i < 5; i++) {
        teste.innerHTML += "<li>Teste " + i + "</li>";
    }
    teste.innerHTML += "</ul>";
})();

Esse bloco de código me gera essa saída:

<ul></ul><li>Teste 0</li><li>Teste 1</li><li>Teste 2</li><li>Teste 3</li><li>Teste 4</li>

O que está em volta do for, é executado primeiro. Só depois, o que está dentro do for é realizado.

Existe uma possibilidade de resolver isso?

Sei que nesse caso, eu poderia criar o elemento ul, e com appendChild inserir os elementos li, mas, esse foi só um exemplo do meu problema.

 

Desde já, grato!

Share this post


Link to post
Share on other sites

Não cara.. nesse caso do exemplo isso ai não acontece não.

O que vem depois do loop espera o loop acabar.

 

Qual foi o caso real em que vc notou o erro ? no código acima, essa situação não acontece.

Share this post


Link to post
Share on other sites

Fala Vinicius o que acontece é o seguinte

 

 

Ao inserir o <ul> ( teste.innerHTML = "<ul>"; ) o dom automaticamente identifica como um elemento e o fecha.

E outro ponto é que você está adicionando o <li> ( teste.innerHTML += "<li>Teste " + i + "</li>"; ) na div pai do <ul> e não nele;

 

O certo seria algo assim:

var i, teste = document.getElementById("entry2172473");
    teste.innerHTML = "<ul id='ListTest'>";
    lista = document.getElementById('ListTest');
    for (i = 0; i < 5; i++) {
        lista.innerHTML += "<li>Teste " + i + "</li>";
    }

Se rodar esse código no console deste tópico verá o resultado;

  • +1 1

Share this post


Link to post
Share on other sites

Não cara.. nesse caso do exemplo isso ai não acontece não.

O que vem depois do loop espera o loop acabar.

 

Qual foi o caso real em que você notou o erro ? no código acima, essa situação não acontece.

 

William, no exemplo, era exatamente o que acontecia. Você não deve nem ter testado...

Obrigado mesmo assim.

:-)

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By gamesmax2
      Então pessoal. tenho um formulário de cadastro, quero que quando o usuário queira, sair da pagina aparecer um alert, por ae tudo bem eu conseguir, só que, minha dificuldade e remover essa função clica no botão de
      <script> window.addEventListener("beforeunload", function (event) { event.returnValue = "Você deseja realmente sair da página?"; }); <script> <a href='finalizar.php' onclick=''> finalizar</a> finalizar, assim ele sair da pagina de boa sem nenhuma alert
    • By luannsr12
      Olá pessoas, estou   utilizando o Google Charts, e me venho a necessidade de usar imagem nos gráficos.
      Alguém já usou, e sabe como fazer?
    • By MEGATRON
      Crie um código em JavaScript que receba 2 palavras, e depois as imprima
      intercaladas. Ex.: “Joao” e “Mary”; a impressão deve ser: “JMoaaroy”. Use uma função
      que receba as duas palavras, e faça a intercalação.
    • By Alyss
      Olá!
       
      Esotu com uma certa dificuldade em um projeto que estou desenvolvendo em relação a funcionalidade drag and drop com jQuery/JavaScript.
       
      <div class="pricipal-menu"> <div class="col-1"> <img src="imagem/1.png"> <img src="imagem/2.png"> <img src="imagem/3.png"> </div> <div class="col-2"> <img src="imagem/1.png"> <img src="imagem/2.png"> <img src="imagem/3.png"> </div> <div class="col-3"> <img src="imagem/1.png"> <img src="imagem/2.png"> <img src="imagem/3.png"> </div> <div class="col-4"> <img src="imagem/1.png"> <img src="imagem/2.png"> <img src="imagem/3.png"> </div> </div> Bom, o que quero fazer é, por exemplo, pegar a img1 da primeira coluna (1, 1) e passá-la para a coluna 2 na posição da img2  (2,2). Até ai tudo bem, o problema é , preciso que quando a img1 for colocada na posição (2,2) a img2 que está na vá para (1,1). Exatamente como um $(...).sortable(), aliás, já tentei até mesmo com o connectWith do sortable(), mas não adianntou muito.
       
      Mais resumidamente, é fazer com que as imagens invertam a posição entre as colunas, mas não sei como.
       
      OBS: já tentei, inclusíve, colocá-las em variáveis pra depois assumirem as posições com o drag'n drop, mas cheguei no mesmo resultado  do connectWith.
       
      Agradeço a atenção!
       
       
    • By Anonicah
      Olá preciso de ajuda com esse exercício. Montei até a parte de formulário + validação de javascrip no dreamweaver mas buguei com o resto. O que eu fiz:
       

      <html>
      <head>
      <title> Formulário CPF validado com Java Script </title>
          
          <script language="javascript" type="text/javascript">
      function validar() {
      var cpf = form1.cpf.value;
          
      if (cpf == "") {
      alert('Preencha o campo com seu cpf');
      form1.cpf.focus();
      return false;
      }
          
      }
      </script>
          
          
      </head>
      <body>
      <form name="form1" action="enviar.php" method="post">
      CPF:
      <input name="cpf" type="text"><br /><br />
      <input type="submit"  onclick="return validar()">
      </form>
      </body>
      </html>
       
       
      EXERCÍCIO
      Criar um formulário simples em html com um único campo CPF;
      Fazer uma validação em javascript antes de fazer o post;
      Consumir o WS https://bi.vidaclass.com.br/utils para consultar informações do CPF enviado pelo form;
      Do retorno obtido exibir na tela:
      Nome, email, telefone
      Se tem compra em saude: Sim | Não
      Quantas compras: (5) ex.
      Se tem farma: Sim | Não
      Se tem dependente: Sim | Não
      Qtd. de dependentes: (2) ex.

      Obtem o token para consumir os endpoints;
      https://bi.vidaclass.com.br/auth
      {
          "company_id": 1,
          "username": "webmaster@vidaclass.com.br",
          "password": "Teste20170705"
      }
      Endpoint para consultar o CPF
      https://bi.vidaclass.com.br/utils
      {
          "action": 4,
          "key": {
              "cpf": 25383193820
          }
      }
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.