Solucionado (ver solução)
Solucionado
(ver solução)
2
respostas

[Bug] Botão

Eu estava fazendo uma aula no ''Lógica de programação: praticando com desaios'' até que eu fui clicar o botão ''sortear'' e ele não está funcionando, eu já havia dado uma olhada no html pra ver se tinha algum erro Insira aqui a descrição dessa imagem para ajudar na acessibilidade

Javascript: function sortear() { let quantidade = parseInt(document.getElementById('quantidade').value); let de = parseInt(document.getElementById('de').value); let ate = parseInt(document.getElementById('ate').value);

let sorteados = []; let numero;

for (let i = 0; 1 < quantidade; i++) { numero = obterNumeroAleatorio(de, ate); sorteados.push(numero); }

alert(sorteados); }

function obterNumeroAleatorio(min, max) { return Math.floor(Math.random() * (max - min + 1)) + min; }

Html:

UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link rel="preconnect" href="https://fonts.googleapis.com">
    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
    <link href="https://fonts.googleapis.com/css2?family=Chakra+Petch:wght@700&family=Inter:wght@400;700&display=swap" rel="stylesheet">
    <link rel="stylesheet" href="style.css">
    <title>Sorteador de números</title>
</head>

<body>
    <div class="container">
        <div class="container__conteudo">
            <div class="container__informacoes">
                <div class="container__texto">
                    <h1>Sorteador<span class="container__texto-azul"> de números</span></h1>

                    <div class="container__campo">
                        <label class="texto__paragrafo">Quantidade de números</label>
                        <input class="container__input" id="quantidade" type="number" min="1">
                    </div>
                    
                    <div class="container__campo">
                        <label class="texto__paragrafo">Do número</label>
                        <input class="container__input" id="de" type="number" min="1">
                    </div>
                    
                    <div class="container__campo">
                        <label class="texto__paragrafo">Até o número</label>
                        <input class="container__input" id="ate" type="number" min="1">
                    </div>
                </div>
                
                <div class="chute container__botoes">
                    <button onclick="sortear()" id="btn-sortear" class="container__botao">Sortear</button>
                    <button onclick="reiniciar()" id="btn-reiniciar" class="container__botao-desabilitado" >Reiniciar</button>
                </div>

                <div class="container__texto" id="resultado">
                    <label class="texto__paragrafo">Números sorteados:  nenhum até agora</label>
                </div>
            </div>

            <img src="./img/ia.png" alt="Uma pessoa com capacete de astronauta" class="container__imagem-pessoa" />
        </div>
    </div>

    <script src="app.js" defer></script>
</body>

</html>
2 respostas

Olá, Kauã M., tudo certo? Vamos dar uma revisada no código?

Estarei focando nos blocos de código responsáveis pelo botão, certo? HTML

html

<div class="chute container__botoes">
    <button onclick="sortear()" id="btn-sortear" class="container__botao">Sortear</button>
    <button onclick="reiniciar()" id="btn-reiniciar" class="container__botao-desabilitado">Reiniciar</button>
</div>

Veja, Kauã, o botão Sortear está com a função onclick definida para o método sortear(). Ou seja, o HTML irá indicar para o JS que o botão foi clicado, e o JS cuidará de todo o restante. Vamos olhar o JS. JavaScript

javascript


function sortear() { 
    let quantidade = parseInt(document.getElementById('quantidade').value); 
    let de = parseInt(document.getElementById('de').value); 
    let ate = parseInt(document.getElementById('ate').value);

    let sorteados = []; 
    let numero;

    for (let i = 0; 1 < quantidade; i++) { 
        numero = obterNumeroAleatorio(de, ate); 
        sorteados.push(numero); 
    }

    alert(sorteados);
}

Pelo que observei no código, o problema principal parece estar no loop for. Na condição do loop, você está usando 1 < quantidade, o que sempre será verdadeiro se a quantidade for maior que 1, fazendo com que o loop continue indefinidamente. O correto seria usar i < quantidade, que é a condição para o loop iterar de acordo com o valor da variável quantidade. Além disso, o valor de i precisa ser inicializado como 0.

solução!

Bom dia, Adriano Jr

Eu reparei que eu tinha colocado 1 ou invés da quantidade, muito obrigado por me ajudar.