Ir para conteúdo

POWERED BY:

Arquivado

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

wneo

While com estrutura com template PHP+tpl

Recommended Posts

Olá!

Estou testando um recurso de template php(abstrair layout html do programa php).

Tenho dúvida em como utilizar o while nessa estrutura:

 

index.php:

<?php
	include_once("../../../model/classes/template.class.php");
	require_once("../../../model/conecta/conecta.php");
	
    $sql = "SELECT * FROM tabela";
    $rs = mysql_query($sql);
	
	while($row = mysql_fetch_array($rs)){
		$id = $row['id'];		
		$nome = $row['nome'];			
	}//end while rs
		
		
	/**
	 * Creates a new template for the user's profile.
	 */
	$profile = new Template("../tpl/index.tpl");	
	$profile->set("nome", $nome);
   
	/**
	 * Outputs the page with the user's profile.
	 */

	echo $profile->output();
?>

index.tpl:

<meta charset="utf-8">

<div class="choose_box">
<ul>
  
<!-- O form estaria no while -->
<form class="">
<p>
<span class="icone icon-archive2"></span>
<span class="big_text">[@nome]</span>
</p>
</form>

<script>
$(document).ready(function(){	

	/* ... */	
	
	/* ... */	

});//end doc
</script>


</ul>
</div><!-- /choose_box-->

Preciso que o form esteja dentro do while, para que dessa forma tenhamos como resultado a visualização de todos os registros dessa tabela nessa disposição.

 

Tentei colocar nessa parte do php, assim:

	while($row = mysql_fetch_array($rs)){
		$id = $row['id'];		
		$nome = $row['nome'];			
	
	
      $profile = new Template("../tpl/index.tpl");	
      $profile->set("nome", $nome);



	}//end while rs
		

Mas das duas formas apenas aparece 1registro... gostaria que todos fossem listados nesse while, que seria em torno do form..

Alguém sabe como?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Fiz mais um estudo na estrutura, e consegui uma evolução, mas ainda falta carregar os dados.

o index.tpl ficou assim:

<meta charset="utf-8">

<h1>Olá...</h1>

<div class="choose_box">
<ul>

[@list_lines]

</ul>
</div><!-- /choose_box-->


<script>
$(document).ready(function(){	

	/* ... */	
	
	/* ... */	

});//end doc
</script>

Criei mais um arquivo chamado list_lines.tpl:

<form class="">
<p>
<span class="icone icon-archive2"></span>
<span class="big_text">[@nome]</span>
</p>
</form>

E o index.php é onde está a questão:

<?php
	include_once("../../../model/classes/template.class.php");
	require_once("../../../model/conecta/conecta.php");

    $sql = "SELECT * FROM tabela";
    $rs = mysql_query($sql);
	
		/*
		while($row = mysql_fetch_array($rs)){
		$id = $row['id'];		
		$nome = $row['nome'];			
		}//end while rs
		*/

	$pipes = array(
			
	array("nome" => "teste1"),
	array("nome" => "teste2"),
	array("nome" => "teste3"),
    
	);
	 
	foreach ($nomes as $nome) {
		$profile = new Template("../tpl/list_lines.tpl");	
	 
		foreach ($nome as $key => $value) {
			$profile->set($key, $value);
		}
		$pipeTemplates[] = $profile;
	}
	$pipeContents = Template::merge($pipeTemplates);
	
	$profile  = new Template("../tpl/index.tpl");
	$profile->set("list_lines", $pipeContents);
	
		
	/**
	 * Creates a new template for the user's profile.
	 */
		
	
	/**
	 * Outputs the page with the user's profile.
	 */

	echo $profile->output();
?>

Com isso, consegui fazer o registro se repetir... Mas como faço para carregar no array os dados da tabela?

	$sql = "SELECT * FROM tabela";
	$rs = mysql_query($sql);	
		/*
		while($row = mysql_fetch_array($rs)){
		$id = $row['id'];		
		$nome = $row['nome'];			
		}//end while rs
		*/

	$pipes = array(
			
	array("nome" => "teste1"),
	array("nome" => "teste2"),
	array("nome" => "teste3"),
    
	);

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Resolvido...

while($row = mysql_fetch_array($rs)){
		$id = $row['id'];		
		$nome = $row['nome'];				

	$pipes = array(		
		 array("id" => $id, "nome" => $nome)		
	);	
	 
	foreach ($pipes as $pipe) {
		$profile = new Template("../tpl/list_lines.tpl");	
	 
		foreach ($pipe as $key => $value) {
			$profile->set($key, $value);
		}//end foreach pipe
		
		$pipeTemplates[] = $profile;
	}//end foreach pipes
	
	}//end while rs
	
	
	$pipeContents = Template::merge($pipeTemplates);
	
	$profile  = new Template("../tpl/index.tpl");
	$profile->set("list_lines", $pipeContents);
	
	/**
	 * Outputs page
	 */
	echo $profile->output();

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por Rafael_Ferreira
      Não consigo carregar a imagem do captcha do meu formulário. Foi testado com o xampp e easyphp. Também não carregou a imagem de outros captcha. 
       
       
    • Por luiz monteiro
      Olá.
      Estou atualizando meu conhecimento com Front-End e me deparei com o seguinte problema.
      Criei um sistema para fazer o upload de imagens e alguns campos text.
      Algo bem simples para depois começar a estudar javascript para mostrar a miniatura....
      Mas quando saio do navegador Chrome ou da aba por mais de 3 minutos, ao retornar o navegador as vezes atualiza ou nem chega atualizar mas limpa os campos.
      Estou usando um Smart Motorola com Android, mas um amigo testou no iPhone e acontece a mesma coisa.
      Gostaria de saber se há como usar javascript para evitar isso?
      Agradeço desde já.

      <!DOCTYPE html>
      <html>
      <head>
          <meta charset="utf-8">
          <meta name="viewport" content="width=device-width, initial-scale=1">
          <title>Uploader</title>
      </head>
      <body>
          <form action="?" method="post" enctype="multipart/form-data">
              <br><br>
              <div>selecione a imagem 1</div>
              <input type="file" name="foto1" accept="image/*">
              <br><br>
              <input type="text" name="nome_imagem1">
              
              <br><br>
              <input type="file" name="foto2" accept="image/*">
              <br><br>
              <input type="text" name="nome_imagem2">
              
              <br><br>

              <input type="file" name="foto3" accept="image/*">
              <br><br>
              <input type="text" name="nome_imagem3">
              
              <br><br>
              <input type="submit" value="Enviar">
              <br><br>
          </form>
      <?php
      if ($_SERVER['REQUEST_METHOD'] == 'POST')
      {
          vardump ($_FILES);
      }
      ?>
      </body>
      </html>
       
       
       
    • Por daemon
      Tenho um site com mais de 50.000 notícias, queria gerar um sitemap.xml.

      Existe algo gratuito ? O site foi desenvolvido do zero.
    • Por daemon
      Tenho um site com mais de 50.000 notícias, queria gerar um sitemap.xml.

      Existe algo gratuito ? O site foi desenvolvido do zero.
    • Por luiz monteiro
      Olá, tudo bem?
       
      Estou melhorando meu conhecimento em php e mysql e, me deparei com o seguinte. A tabela da base de dados tem um campo do tipo varchar(8) o qual armazena números. Eu não posso alterar o tipo desse campo. O que preciso é fazer um select para retornar o números que contenham zeros a direita ou a esquerda.
      O que tentei até agora
       
      Ex1
      $busca = $conexao->prepare("select campo form tabela where (campo = :campo) ");
      $busca->bindParam('campo', $_REQUEST['campo_form']);
       
      Se a direita da string $_REQUEST['campo_form'] termina ou inicia com zero ou zeros, a busca retorna vazio.
      Inseri dados numéricos, da seguinte maneira para testar: 01234567;  12345670: 12345678: 12340000... entre outros nessa coluna. Todos os valores que não terminam ou não iniciam com zero ou zeros, o select funciona.
       
       
      Ex2
      $busca = $conexao->prepare("select campo form tabela where (campo = 0340000) ");
      Esse número está cadastrado, mas não retorna.
       
      Ex3
      $busca = $conexao->prepare("select campo form tabela where (campo = '02340001' ) ");
      Esse número está cadastrado, mas não retorna.
       
       
      Ex4
      $busca = $conexao->prepare("select campo form tabela where (campo like 2340000) ");
      Esse número está cadastrado, mas não retorna.
       
      Ex5
      $busca = $conexao->prepare("select campo form tabela where (campo like '12340000') ");
      Esse número está cadastrado, mas não retorna.
       
      Ex6
      $busca = $conexao->prepare("select campo form tabela where (campo like '"12340000"' ) ");
      Esse número está cadastrado, mas não retorna.
       
       
      Ex7
      $busca = $conexao->prepare("select campo form tabela where (campo like :campo) ");
      $busca->bindParam('campo', $_REQUEST['campo_form'])
      Não retorna dados.
       
      O  $_REQUEST['campo_form'] é envio via AJAX de um formulário. 
      Usei o gettype para verificar o post, e ele retorna string.
      Fiz uma busca com número 12345678 para verificar o que o select retorna, e também retrona como string.
       
      Esse tipo de varchar foi usado porque os números que serão gravados nesse campo,  terão zeros a direita ou na esquerda. Os tipos number do mysql não gravam zeros, então estou usando esse. O problema é a busca.
      Agradeço desde já.
       
       
×

Informação importante

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