0 Compartilhamentos 480 Views

Do MySQL para o jQuery usando PHP, XML e AJAX

30 de agosto de 2012

Este tutorial assume que você sabe como se conectar ao seu banco de dados. Ele também presume que você tenha uma configuração de tabela chamada "pessoas" com 3 colunas: "título", "nome" e "email".

Insira alguns dados para esta tabela.

Estrutura do XML

A idéia deste tutorial é ler um arquivo XML com uma chamada de AJAX do jQuery, portanto é necessário estruturar nossos dados corretamente. Aqui está um exemplo da estrutura do que nosso documento XML irá gerar:

Arquivo <i>"pessoas.xml"</i>:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>

<pessoas>

<pessoa>

<nome titulo="Sr">Joao</nome>
<email>[email protected]</email>

</pessoa>

<pessoa>

<nome titulo="Sra">Maria</nome>
<email>[email protected]</email>

</pessoa>

</pessoas>

O código PHP para criar o arquivo XML

Primeiro, iremos obter os dados do banco de dados e então por meio de cada resultado de linha para gerar o XML. Faremos isso utilizando a função PHP DOMDocument() que cria um documento XML para "nós" e também permite adicionar "nós" e as "child" para o XML dinamicamente.

Arquivo <i>"criararquivoxml.php"</i>:

<?php

$query = "SELECT titulo,nome,email FROM pessoas";
$result = mysql_query($query);

$xml = "";

while($array = mysql_fetch_array($result)) {

$title = $array[[‘titulo’]];
$firstname = $array[[‘nome’]];
$surname = $array[[‘email’]];

$xml .= "tt<pessoa>n";
$xml .= "ttt<nome titulo="$titulo">$nome</nome>n";
$xml .= "ttt<email>$email</email>n";
$xml .= "tt</pessoa>n";

}

header(‘Content-Type: application/xml; charset=ISO-8859-1’);
echo "<?xml version="1.0" encoding="UTF-8" standalone="yes"?>n";
echo "t<pessoas>n";
echo $xml;
echo "t</pessoas>n";
?>

Em seguida precisamos salvar o arquivo XML. A forma como fazemos isso é dizer o arquivo PHP para salvar o documento XML com a função de saveXML(), obtem o script PHP para responder com um cabeçalho de tipo XML. Assim, após o código acima, adicione isso:

$xml_string = $doc->saveXML();
header(‘Content-Type: application/xml; charset=ISO-8859-1’);
echo $xml_string;

A parte do cabeçalho informa ao navegador que este é um tipo de conteúdo XML, e o resto é simplesmente a estrutura de dados XML, como mencionado anteriormente. Espero que agora, quando você executar esse script PHP, você deve retornar um documento XML válido.

Ajax com jQuery

A última peça para este quebra-cabeça é conseguir ler os dados XML em uma página HTML usando jQuery e ajax. Você precisa incluir, obviamente, a biblioteca jQuery, eu também estou incluindo um arquivo javascript externo para o nosso código de jQuery. Assim, vá em frente e crie um arquivo de javascript chamado scripts.js e colocar o código abaixo para ele:

$(document).ready(function() {
$("#getData").click(function(){
var data = "";
$.get("pessoas.xml", function(theXML){
$(‘pessoa’,theXML).each(function(i){
var titulo = $(this).find("nome").attr("titulo");
var nome = $(this).find("nome").text();
var email = $(this).find("email").text();
data = data + "Nome: " + titulo + " " + nome + " – E-mail: " + email + "<br>";
});
$("#container").html(data);
});
});
});

 

Este código fará a chamada do evento de clique do botão e, em seguida, trás os dados via GET AJAX para o script PHP que fizemos anteriormente. Uma vez que receber os dados do arquivo XML, este interage em cada nó de “pessoa”. Observe que estou retornando duas diferentes fontes de dados de XML, os dados entre as marcas “nome” assim como também retornando os dados para um atributo de nó XML, o “título”.

Carregando...

Você pode se interessar

Como a Nvidia está usando rede neural no lugar de codecs de vídeo
Artigos
6 visualizações
Artigos
6 visualizações

Como a Nvidia está usando rede neural no lugar de codecs de vídeo

Carlos L. A. da Silva - 25 de novembro de 2020

Maxine é uma solução de aprendizado de máquina na nuvem que reduz a quantidade de dados transmitidos, deduzindo e gerando as partes que faltam.

Promoções de Jogos do Final de Semana (20/11)
Notícias
12 visualizações
Notícias
12 visualizações

Promoções de Jogos do Final de Semana (20/11)

Carlos L. A. da Silva - 20 de novembro de 2020

Confira as melhores ofertas de jogos de PC para o final de semana.

Top 10 soft skills para desenvolvedores
Artigos
14 visualizações
Artigos
14 visualizações

Top 10 soft skills para desenvolvedores

Carlos L. A. da Silva - 20 de novembro de 2020

Não basta saber programar bem... confira o que as empresas também estão procurando em um profissional de desenvolvimento.

Deixe um Comentário

Your email address will not be published.

Mais publicações

Como detectar um bloqueador de anúncios usando uma linha de Javascript
Dicas
18 visualizações
18 visualizações
Promoções de Jogos do Final de Semana (13/11)
Notícias
23 visualizações
23 visualizações

Promoções de Jogos do Final de Semana (13/11)

Carlos L. A. da Silva - 13 de novembro de 2020
Como extrair imagens de um documento Word/LibreOffice com inteligência
Dicas
22 visualizações
22 visualizações
Promoções de Jogos do Final de Semana (06/11)
Notícias
27 visualizações
27 visualizações

Promoções de Jogos do Final de Semana (06/11)

Carlos L. A. da Silva - 6 de novembro de 2020