Tutoriais AMP

Como criar um Iframe Redimensionável no AMP

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

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 documento 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:

<div overflow tabindex=”0″ role=”button” class=”ampstart-card py1″ aria-label=”Show more”>Clique aqui para mostrar mais</div>

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.

 

Post Recentes

CNPJ alfanumérico Magento 2: módulo grátis com máscara e validação

Módulo gratuito Roger_CnpjAlfanumerico que aplica máscara e validação do novo CNPJ alfanumérico no checkout e formulários do Magento 2 e…

4 dias atrás

CNPJ alfanumérico no WooCommerce: plugin grátis de máscara e validação

A partir de 06/07/2026 a Receita passa a emitir CNPJ alfanumérico. Conheça o plugin grátis que aplica máscara e validação…

4 dias atrás

Como remover um modulo do Magento 2

Para remover um módulo do Magento 2, siga os passos abaixo: 1. Desabilitar o módulo Primeiro, desabilite o módulo usando…

1 ano atrás

Criar um memorando de crédito (cancelar) invoice no Magento 2

Para cancelar 100% do pedido e criar um crédito para todos os itens através da API REST do Magento 2,…

2 anos atrás

Consultando no banco quantidade disponivel para Venda (estoque)

No Magento 2, a quantidade "reservada" na "Salable Quantity" é gerenciada principalmente pelos módulos MSI (Multi-Source Inventory). A "Salable Quantity"…

2 anos atrás

Admin do Magento 2 não acessa

Como corrigir o erro ao acessar o Admin do Magento 2. Mesmo após fazer o login, permanece na tela de…

2 anos atrás