O que é: XHR (XMLHttpRequest)

O XMLHttpRequest (XHR) é um objeto JavaScript que permite que as páginas da web interajam com servidores web de forma assíncrona. Ele é amplamente utilizado para enviar e receber dados em segundo plano, sem a necessidade de recarregar a página inteira. Neste artigo, vamos explorar em detalhes o que é o XHR e como ele funciona.

O que é o XHR?

O XMLHttpRequest (XHR) é uma API que fornece uma maneira fácil de buscar informações de um servidor web sem a necessidade de atualizar a página. Ele permite que os desenvolvedores enviem solicitações HTTP assíncronas para o servidor e recebam os dados de resposta sem interromper a experiência do usuário.

Como o XHR funciona?

Quando um desenvolvedor cria uma instância do objeto XMLHttpRequest, ele pode especificar o tipo de solicitação que deseja fazer, como GET, POST, PUT ou DELETE. Em seguida, o desenvolvedor pode definir o URL do servidor para onde a solicitação será enviada.

Após a configuração da solicitação, o desenvolvedor pode chamar o método open() para iniciar a solicitação. O método open() recebe três parâmetros: o método HTTP, o URL do servidor e um parâmetro opcional para especificar se a solicitação deve ser assíncrona ou síncrona. Geralmente, é recomendado usar a opção assíncrona para evitar bloquear a interface do usuário.

Depois que a solicitação é aberta, o desenvolvedor pode definir os cabeçalhos da solicitação usando o método setRequestHeader(). Isso é útil para enviar informações adicionais para o servidor, como tokens de autenticação ou informações de sessão.

Uma vez que a solicitação esteja completamente configurada, o desenvolvedor pode enviá-la para o servidor usando o método send(). Se a solicitação for assíncrona, o código JavaScript continuará a ser executado enquanto a solicitação é processada em segundo plano.

Recebendo a resposta

Quando o servidor recebe a solicitação, ele processa os dados e envia uma resposta de volta para o cliente. O objeto XMLHttpRequest captura essa resposta e a disponibiliza para o desenvolvedor através de várias propriedades e métodos.

Uma das propriedades mais importantes é a propriedade readyState, que indica o estado atual da solicitação. Existem cinco valores possíveis para a propriedade readyState: 0 (UNSENT), 1 (OPENED), 2 (HEADERS_RECEIVED), 3 (LOADING) e 4 (DONE). O valor 4 indica que a solicitação foi concluída e a resposta está pronta para ser processada.

Para acessar os dados da resposta, o desenvolvedor pode usar a propriedade responseText, que contém o conteúdo da resposta como uma string. Se a resposta for um documento XML, o desenvolvedor também pode usar a propriedade responseXML para acessar os dados de forma estruturada.

Além disso, o desenvolvedor pode verificar o código de status da resposta usando a propriedade status. O código de status é um número que indica se a solicitação foi bem-sucedida (200), redirecionada (300), com erro do cliente (400) ou com erro do servidor (500).

Tratando erros

É importante lidar com possíveis erros durante o processo de solicitação e resposta. O objeto XMLHttpRequest fornece uma propriedade onerror, que pode ser usada para definir uma função de tratamento de erros personalizada. Essa função será chamada se ocorrer algum erro durante a solicitação.

Além disso, o objeto XMLHttpRequest também fornece eventos que podem ser usados para lidar com diferentes estágios da solicitação. Por exemplo, o evento onreadystatechange é acionado sempre que o valor da propriedade readyState é alterado. Isso permite que o desenvolvedor atualize a interface do usuário ou execute outras ações com base no estado da solicitação.

Segurança e restrições

Devido a preocupações de segurança, o XHR está sujeito a algumas restrições. Por padrão, o XHR só pode fazer solicitações para o mesmo domínio do qual a página foi carregada. Isso é conhecido como política de mesma origem. No entanto, existem maneiras de contornar essa restrição, como o uso de cabeçalhos CORS (Cross-Origin Resource Sharing) ou proxies.

Além disso, alguns navegadores podem impor limites no número máximo de solicitações XHR que podem ser feitas em paralelo. Isso é feito para evitar abusos e melhorar o desempenho do navegador.

Conclusão

O XMLHttpRequest (XHR) é uma poderosa API que permite que as páginas da web interajam com servidores web de forma assíncrona. Ele é amplamente utilizado para criar aplicativos web dinâmicos e responsivos, onde os dados podem ser atualizados em tempo real sem a necessidade de recarregar a página inteira. Com o XHR, os desenvolvedores têm controle total sobre as solicitações e respostas HTTP, permitindo a criação de experiências de usuário mais ricas e interativas.

//loguksoorto.net/4/6850264