Ferramentas para capturar e converter a Web

Como aguardar o carregamento de uma página da web antes de realizar uma captura?

Um item em uma página da web carregando após o conteúdo principal

Algumas páginas da web podem demorar um pouco para carregar ou ter conteúdo específico que você está intinteressado em que pode carregar após o carregamento da página principal. Isso é especialmente verdadeiro em páginas da web pesadas em AJAX, onde o conteúdo é carregado via JavaScript.

GrabzIt detecta quando uma página da web carrega, mas para algumas das circunstâncias específicas listadas acima, ele precisa de algumas instruções adicionais na forma de um atraso que deve ser usado antes da captura ser realizada ou aguardando que um elemento HTML especificado apareça antes da captura ser realizada à frente. Essas técnicas podem ser usadas se você estiver fazendo capturas de tela de páginas da web ou convertendo HTML into PDF's, imagens ou documentos Word, e você tem um pacote premium. No entanto, ambas as técnicas estão limitadas a um tempo de espera máximo de trinta segundos.

É uma boa ideia não usar um atraso muito grande porque no caso incomum de capturas serem enfileiradas, um atraso grande reduzirá a prioridade de captura, embora haja alguns soluções inteligentes para isso.

Esses recursos também estão disponíveis em nosso captura de tela on-line e raspador de teia ferramentas.

Como esperar um tempo determinado antes de realizar uma captura?

Basta especificar o atraso em milissegundos e é quanto tempo a captura irá aguardar. Lembre-se de que existem 1000 milissegundos em um segundo. Todos os exemplos abaixo esperam três segundos antes de capturar a página da web.

GrabzItClient grabzIt = new GrabzItClient("Sign in to view your Application Key", "Sign in to view your Application Secret");
ImageOptions options = new ImageOptions();
options.Delay = 3000;
grabzIt.URLToImage("http://www.spacex.com", options);
grabzIt.SaveTo("images/result.jpg");
GrabzItClient grabzIt = new GrabzItClient("Sign in to view your Application Key", "Sign in to view your Application Secret");
ImageOptions options = new ImageOptions();
options.setDelay(3000);
grabzIt.URLToImage("http://www.spacex.com", options);
grabzIt.SaveTo("images/result.jpg");
<script src="https://cdn.jsdelivr.net/npm/@grabzit/js@3.5.2/grabzit.min.js"></script>
<script>
GrabzIt("Sign in to view your Application Key").ConvertURL("http://www.spacex.com", 
{"delay": 3000}).Create();
</script>
var grabzit = require('grabzit');

var client = new grabzit("Sign in to view your Application Key", "Sign in to view your Application Secret");
var options = {"delay":"3000"};
client.url_to_image("http://www.spacex.com", options);
client.save_to("images/result.jpg", function (error, id){
    if (error != null){
        throw error;
    }
});
$grabzIt = GrabzItClient->new("Sign in to view your Application Key", "Sign in to view your Application Secret");
$options = GrabzItImageOptions->new();
$options->delay(3000);
$grabzIt->URLToImage("http://www.spacex.com", $options);
$grabzIt->SaveTo("images/result.jpg");
$grabzIt = new \GrabzIt\GrabzItClient("Sign in to view your Application Key", "Sign in to view your Application Secret");
$options = new \GrabzIt\GrabzItImageOptions();
$options->setDelay(3000);
$grabzIt->URLToImage("http://www.spacex.com", $options);
$grabzIt->SaveTo($filepath);
grabzIt = GrabzItClient.GrabzItClient("Sign in to view your Application Key", "Sign in to view your Application Secret")
options = GrabzItImageOptions.GrabzItImageOptions()
options.delay = 3000
grabzIt.URLToImage("http://www.spacex.com", options)
grabzIt.SaveTo("images/result.jpg")
https://api.grabz.it/services/convert?key=Sign in to view your Application Key&format=jpg&delay=3000&url=https%3A%2F%2Fspacex.com%2F
grabzIt = GrabzIt::Client.new("Sign in to view your Application Key", "Sign in to view your Application Secret")
options = GrabzIt::ImageOptions.new()
options.delay = 3000
grabzItClient.url_to_image("http://www.spacex.com", options)
grabzItClient.save_to("images/result.jpg")

Como esperar que um elemento HTML apareça antes de realizar uma captura?

Essa técnica é especialmente útil em páginas da web que usam métodos AJAX para carregar conteúdo. Primeiro use as ferramentas de desenvolvedor do seu navegador para identificar o elemento que você precisa esperar para aparecer, anote seu id, classe ou faça um seletor CSS mais complicado. Então especifique isso Seletor CSS e assim que o elemento se torna visível, a página da web é capturada. Observe que se houver vários elementos HTML correspondentes, ele aparecerá assim que um estiver visível.

GrabzItClient grabzIt = new GrabzItClient("Sign in to view your Application Key", "Sign in to view your Application Secret");
ImageOptions options = new ImageOptions();
options.WaitForElement = "#Content";
grabzIt.URLToImage("http://www.spacex.com", options);
grabzIt.SaveTo("images/result.jpg");
GrabzItClient grabzIt = new GrabzItClient("Sign in to view your Application Key", "Sign in to view your Application Secret");
ImageOptions options = new ImageOptions();
options.setWaitForElement("#Content");
grabzIt.URLToImage("http://www.spacex.com", options);
grabzIt.SaveTo("images/result.jpg");
<script src="https://cdn.jsdelivr.net/npm/@grabzit/js@3.5.2/grabzit.min.js"></script>
<script>
GrabzIt("Sign in to view your Application Key").ConvertURL("http://www.spacex.com", 
{"waitfor": "#Content"}).Create();
</script>
var grabzit = require('grabzit');

var client = new grabzit("Sign in to view your Application Key", "Sign in to view your Application Secret");
var options = {"waitForElement":"#Content"};
client.url_to_image("http://www.spacex.com", options);
client.save_to("images/result.jpg", function (error, id){
    if (error != null){
        throw error;
    }
});
$grabzIt = GrabzItClient->new("Sign in to view your Application Key", "Sign in to view your Application Secret");
$options = GrabzItImageOptions->new();
$options->waitForElement("#Content");
$grabzIt->URLToImage("http://www.spacex.com", $options);
$grabzIt->SaveTo("images/result.jpg");
$grabzIt = new \GrabzIt\GrabzItClient("Sign in to view your Application Key", "Sign in to view your Application Secret");
$options = new \GrabzIt\GrabzItImageOptions();
$options->setWaitForElement("#Content");
$grabzIt->URLToImage("http://www.spacex.com", $options);
$grabzIt->SaveTo($filepath);
grabzIt = GrabzItClient.GrabzItClient("Sign in to view your Application Key", "Sign in to view your Application Secret")
options = GrabzItImageOptions.GrabzItImageOptions()
options.waitForElement = "#Content"
grabzIt.URLToImage("http://www.spacex.com", options)
grabzIt.SaveTo("images/result.jpg")
https://api.grabz.it/services/convert?key=Sign in to view your Application Key&format=jpg&waitfor=%23Content&url=https%3A%2F%2Fspacex.com%2F
grabzIt = GrabzIt::Client.new("Sign in to view your Application Key", "Sign in to view your Application Secret")
options = GrabzIt::ImageOptions.new()
options.waitForElement = "#Content"
grabzItClient.url_to_image("http://www.spacex.com", options)
grabzItClient.save_to("images/result.jpg")

Esta técnica pode ser usada em conjunto com o método de atraso mencionado primeiro. Permitindo que você espere que um elemento HTML apareça e depois aguarde mais um período de tempo antes de criar a captura.