Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

arthurcastro

While PHP com DIVs diferentes...

Recommended Posts

Olá! Tudo bem? :)
Sou leigo em PHP mas consegui criar um sistema de exibição de postagens, entretanto me bateu uma dúvida.
Meu código repete tudo que tenho no banco de dados mas no layout, eu gostaria de fazer algumas divs diferente de outras. Isso é possível?


Eu tenho a div-news ( <div class="div-news"></div>) que está sendo repetida. Tem como fazer por exemplo uma div-news_2 no meio disso e mesmo assim continuar replicando o banco de dados normalmente?


Segue meu código:

 <?php
  $sqli = "SELECT * from tb_postagens WHERE exibir='Sim' ORDER BY id DESC LIMIT 20";
    try{
	  $resultado = $conexao->prepare($sqli);
	  $resultado->execute();
	  $contar = $resultado->rowCount();
	  
	  if($contar >0){
	  
       while($exibe = $resultado->fetch(PDO::FETCH_OBJ)){
		   
?>	
	
	
    <div class="div-news">
	<a style="text-decoration:none" href="visualizar.php?id=<?php echo $exibe->id;?>&Materia=<?php echo strip_tags($exibe->titulo);?>">
  <img class="overlay" src="upload/postagens/<?php echo $exibe->imagem;?>" width="100%" height="180"/>
  </a>
      <a style="text-decoration:none" href="noticia/?regiao=<?php echo $exibe->categoria;?>&<?php echo $exibe->data;?>&id=<?php echo $exibe->id;?>&materia=<?php echo strip_tags(str_replace(" ","_", $exibe->titulo));?>" class="news">
  <h2><?php echo $exibe->titulo;?></h2>
  <p class="home"><?php echo limitarTexto(strip_tags($exibe->descricao), $limite=100);?></p>
  </a>
		
	</div>
	
	 <?php
}//while
	  
	  
}else{
	  echo '<li>Não há nada por aqui :(</li>';
	  }
	  
  }catch(PDOException $erro){ echo $erro;}
  
  ?>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Olá @arthurcastro

 

Tente usando o "for".

Dei uma refatorada no seu código e tá funcionando de boa, a cada loop a div vai ficar "div-new_1", "div-new_2" e assim até o número do contador com o incremente ser igual ao número de linhas retornada do banco de dados.

 

Adicionado não fiz o uso do "While".

for($i = 1; $i <= $contar; $i++) :
            $exibe = $stmt->fetch(PDO::FETCH_OBJ);

 <div class="div-news_<?php echo $i ?>">

 

<?php
  $sqli = "SELECT * from tb_postagens WHERE exibir='Sim' ORDER BY id DESC LIMIT 20";
    try{
	  $resultado = $conexao->prepare($sqli);
	  $resultado->execute();
	  $contar = $resultado->rowCount();
	  
	  if($contar >0){
    
        for($i = 1; $i <= $contar; $i++) :
            $exibe = $stmt->fetch(PDO::FETCH_OBJ);		   
?>	
	
	
    <div class="div-news_<?php echo $i ?>">
	    <a style="text-decoration:none" href="visualizar.php?id=<?php echo $exibe->id;?>&Materia=<?php echo strip_tags($exibe->titulo);?>">
            <img class="overlay" src="upload/postagens/<?php echo $exibe->imagem;?>" width="100%" height="180"/>
        </a>
        <a style="text-decoration:none" href="noticia/?regiao=<?php echo $exibe->categoria;?>&<?php echo $exibe->data;?>&id=<?php echo $exibe->id;?>&materia=<?php echo strip_tags(str_replace(" ","_", $exibe->titulo));?>" class="news">
            <h2><?php echo $exibe->titulo;?></h2>
            <p class="home"><?php echo limitarTexto(strip_tags($exibe->descricao), $limite=100);?></p>
        </a>
	</div>
	
<?php
    endfor;
	  
	  
}else{
	  echo '<li>Não há nada por aqui :(</li>';
	  }
	  
  }catch(PDOException $erro){ echo $erro;}
  
 ?>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Olá!
Qual seria o objetivo?

Talvez dê pra acrescentar outra class usando algum valor em  $exibe como parâmetro.
Mas o que é que você precisa fazer?
 

Compartilhar este post


Link para o post
Compartilhar em outros sites

tetsuo, parece que com a repetição while, não funciona. Testei manualmente e funcionou mas quando aplico no html que está envolvido pela repetição do php, não vai.
Ficou assim para teste:

<style>
.div-news:nth-child(1){
	width: 500px;
    background-color: lime;
}
</style>

<div class="div-news">1</div>
<div class="div-news">2</div>


Além disso, eu preciso também reposicionar alguns elementos nas divs que serão alteradas, com o nth não dá pra fazer isso.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Oi Thiago! Obrigado pela ajuda! O seu código funciona, mas apesar de renomear a class da div ele ainda repete tudo e não consigo alterar uma adicionar nada numa div sozinha. Tem como fazer ele parar a repetição em um número ou começar de algum? Por exemplo começar a repetir a partir do 3...

Compartilhar este post


Link para o post
Compartilhar em outros sites

Olá @arthurcastro

 O código que te passei é adicionado o número do contador a cada loop então ficaria assim:

<div class="div-news_1">
<div class="div-news_2">
<div class="div-news_3">

A cada loop seria incrementado +1.

 

Mas como você que aplicar estilo diferente a cada linha tente da forma que o @tetsuo disse

 

 

 

<!DOCTYPE html>
<html lang="pt-br">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>DIV</title>
    <style>
        /* Aplica nos elementos ímpares */
        .div-news:nth-child(odd) {
            font-size: 16pt;
            width: 500px;
            background-color:red;
        }

      	/* Aplica nos elementos pares */
        .div-news:nth-child(even) {
            font-size: 28pt;
            width: 700px;
            height: 200px;
            background-color: lime;
        }
    </style>
</head>
<body>

        <div class="div-news">1</div>
        <div class="div-news">2</div>
    
</body>
</html>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por violin101
      Caros amigos, saudações.
       
      Por favor, poderiam me ajudar.

      Estou com a seguinte dúvida:
      --> como faço para para implementar o input código do produto, para quando o usuário digitar o ID o sistema espera de 1s a 2s, sem ter que pressionar a tecla ENTER.

      exemplo:
      código   ----   descrição
           1       -----   produto_A
       
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Humildemente peço desculpa por postar uma dúvida que tenho.

      Preciso salvar no MySql, os seguinte Registro:

      1 - Principal
      ====> minha dúvida começa aqui
      ==========> como faço para o Sistema Contar Automaticamente o que estiver despois do 1.____?
      1.01 - Matriz
      1.01.0001 - Estoque
      1.01.0002 - Oficina
      etc

      2 - Secundário
      2.01 - Loja_1
      2.01.0001 - Caixa
      2.01.0002 - Recepção
      etc
       
      Resumindo seria como se fosse um Cadastro de PLANO de CONTAS CONTÁBEIL.

      Grato,


      Cesar









       
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer a orientação dos amigos.

      Preciso fazer um Relatório onde o usuário pode Gerar uma Lista com prazo para vencimento de: 15 / 20/ 30 dias da data atual.

      Tem como montar uma SQL para o sistema fazer uma busca no MySql por período ou dias próximo ao vencimento ?

      Tentei fazer assim, mas o SQL me traz tudo:
      $query = "SELECT faturamento.*, DATE_ADD(faturamento.dataVencimento, INTERVAL 30 DAY), fornecedor.* FROM faturamento INNER JOIN fornecedor ON fornecedor.idfornecedor = faturamento.id_fornecedor WHERE faturamento.statusFatur = 1 ORDER BY faturamento.idFaturamento $ordenar ";  
      Grato,
       
      Cesar
       
       
       
       
    • Por violin101
      Caros amigos, saudações
       
      Por favor, me perdoa em recorrer a orientação dos amigos, tenho uma dúvida.
       
      Gostaria de uma rotina onde o Sistema possa acusar para o usuário antes dos 30 dias, grifar na Tabela o aviso de vencimento próximo, por exemplo:
       
      Data Atual: 15/11/2024
                                           Vencimento
      Fornecedor.....................Data.....................Valor
      Fornecedor_1...........01/12/2024..........R$ 120,00 <== grifar a linha de Laranja
      Fornecedor_1...........01/01/2025..........R$ 130,00
      Fornecedor_2...........15/12/2024..........R$ 200,00 <== grifar a linha de Amarelo
      Fornecedor_2...........15/01/2025..........R$ 230,00
      Fornecedor_3...........20/12/2024..........R$ 150,00
       
      Alguém tem alguma dica ou leitura sobre este assunto ?

      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer a ajuda dos amigos, mas preciso entender uma processo que não estou conseguindo sucesso.

      Como mencionado no Título estou escrevendo um Sistema Web para Gerenciamento de Empresa.
       
      Minha dúvida, que preciso muito entender:
      - preciso agora escrever a Rotina para Emissão de NFe e essa parte não estou conseguindo.
       
      tenho assistido alguns vídeos e leituras, mas não estou conseguindo sucesso, já fiz toda as importações das LIB da NFePhp conforme orientação.

      Preciso de ajuda.

      Algum dos amigos tem conhecimento de algum passo-a-passo explicando a criação dessa rotina ?

      tenho visto alguns vídeos com LARAVEL, mas quando tento utilizar e converter para PHP+Codeiginter, dá uma fila de erros que não entendo, mesmo informando as lib necessárias.

      Alguns do amigo tem algum vídeo, leitura explicando essa parte ?

      Grato,

      Cesar.
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.