Como criar um Iframe Redimensionável no AMP

Como criar um Iframe Redimensionável no , requisitos e implementações necessárias para que seja possível alterar a altura e largura do Iframe.

Como criar um Iframe Redimensionável no AMP

Componente necessária para a utilização do amp-iframe, inclua no Header do seu projeto.

<script async custom-element="amp-iframe" src="https://cdn.ampproject.org/v0/amp-iframe-0.1.js"></script>

Requisitos para criar um Iframe Redimensionável no AMP

Uma característica importante do amp-iframe é a capacidade de redimensionar o iframe em tempo de execução. Para que isso funcione será necessário seguir os seguintes critérios:

O amp-iframe deve ter definido o atributo allow-same-origin no atributo sandbox .

O amp-iframe deve ser definido com o atributo resizable.

O amp-iframe deve ter um elemento secundário com atributo overflow.

O iframe deve enviar uma solicitação embed-size

Modelo da solicitação “request”:

window.parent.postMessage({
  sentinel: 'amp',
  type: 'embed-size',
  height: document.body.scrollHeight,
  width: document.body.scrollWidth,
}, '*');

Este requisição é enviada utilizando o postMessage.

A mesma será solicitada pelo iframe, durante a execução.

Utilizando do document.body.scrollHeightdocument.body.scrollWidth, ajustamos o tamanho do iframe na página de acordo com o seu conteúdo.

Modelo o amp-iframe:

<amp-iframe width="150"
  height="150"
  sandbox="allow-scripts allow-same-origin"
  resizable
  frameborder="0"
  src="https://rogertakemiya.com.br"
  class="m1">
  <div overflow
    tabindex="0"
    role="button"
    class="ampstart-card py1"
    aria-label="Show more">Clique aqui para mostrar mais</div>
</amp-iframe>

Observe o atributo resizable na tag.

A div com atributo overflow:

Observação: Obviamente o conteúdo do iframe será substituído pela página que está definida no atributo SRC,  atenção, você deve escrever a tag iframe já com a div dentro! Não confunda! A div com atributo overflow não deve estar na página do SRC!

E o sandbox com os valores: allow-scripts e allow-same-origin.

 

Dúvidas? Faça um comentário logo abaixo ou envie uma mensagem clicando aqui.

O seu endereço de e-mail não será publicado. Campos obrigatórios são marcados com *