Как использовать onclick на странице усилителя - PullRequest
0 голосов
/ 26 августа 2018

Я пытаюсь преобразовать мою текущую страницу в страницу усилителя, но у меня возникли некоторые проблемы с атрибутами onclick.в любом случае, чтобы добавить эту функциональность на странице усилителя.вот тег, который я хочу конвертировать

<img src="theSrc"
     alt=""
     onclick="window.open('link', 'Popup','toolbar=no, location=no, statusbar=no, menubar=no, scrollbars=1, resizable=0, width=580, height=600, top=30')"
     style="cursor:pointer"
     id="someID"
/>

Ответы [ 2 ]

0 голосов
/ 30 августа 2018

Ваш код кажется, что вы хотите показать изображение, ссылку и всплывающее окно

<img src="theSrc"
     alt=""
     onclick="window.open('link', 'Popup','toolbar=no, location=no, statusbar=no, menubar=no, scrollbars=1, resizable=0, width=580, height=600, top=30')"
     style="cursor:pointer"
     id="someID"
/>

Вы можете достичь своей цели комбинацией amp-img, amp-lightbox и amp-iframe

Вот рабочий URL

Код:

<!doctype html>
<html amp>
 <head>
   <meta charset="utf-8">
   <link rel="canonical" href="popup.html">
   <meta name="viewport" content="width=device-width,minimum-scale=1,initial-scale=1">
   <style amp-boilerplate>body{-webkit-animation:-amp-start 8s steps(1,end) 0s 1 normal both;-moz-animation:-amp-start 8s steps(1,end) 0s 1 normal both;-ms-animation:-amp-start 8s steps(1,end) 0s 1 normal both;animation:-amp-start 8s steps(1,end) 0s 1 normal both}@-webkit-keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}@-moz-keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}@-ms-keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}@-o-keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}@keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}</style><noscript><style amp-boilerplate>body{-webkit-animation:none;-moz-animation:none;-ms-animation:none;animation:none}</style></noscript>
   <script async src="https://cdn.ampproject.org/v0.js"></script>
   <script async custom-element="amp-lightbox" src="https://cdn.ampproject.org/v0/amp-lightbox-0.1.js"></script>
   <script async custom-element="amp-iframe" src="https://cdn.ampproject.org/v0/amp-iframe-0.1.js"></script>
     <style amp-custom>
    .lightbox {
      background: rgba(0,0,0,0.8);
      width: 580px;
      height: 600px;
      margin:30px auto;
      padding:30px;
      position:relative;
    }
    .close { position:absolute; right:5px; top:5px; color: red;    font-family: arial;    font-size: 25px;} 

  </style>

 </head>
 <body>


  <amp-lightbox id="Popup" layout="nodisplay">
    <div class="lightbox" >
      <span class="close" on="tap:Popup.close" role="button" tabindex="0">X</span>
      <amp-iframe width="580" title="Animated dancing GIF from Giphy"
                          height="600"
                          layout="responsive"
                          sandbox="allow-scripts allow-same-origin allow-popups"
                          frameborder="0"
                          src="https://giphy.com/embed/DKG1OhBUmxL4Q">
    <amp-img layout="fill"
    src="https://i.vimeocdn.com/video/536538454_640.webp"
    placeholder></amp-img>
    </amp-iframe>
    </div>
  </amp-lightbox>
  <span class="ampstart-btn caps m2" on="tap:Popup" role="button" tabindex="0">
    <amp-img src="https://dummyimage.com/200x50/ff0000/ffffff&text=Click+Here+Image" width="200" height="50" layout="fixed"></amp-img>
  </span>


 </body>
</html>
0 голосов
/ 27 августа 2018

AMP позволяет использовать атрибут «on», внутри которого вы можете определять различные действия, соответствующие поддерживаемым событиям (см. Действия и события AMP ). Поэтому ваш код должен выглядеть примерно так:

<amp-img src=" "
     alt=""
     role=""
     tabindex=""
     on="tap: <your action here>"
     style=" "
     id=" "
>
<!-- 'role' and 'tabindex' attributes are mandatory when using 'on' attribute
      in some html elements like Bachcha Singh pointed out in the comments.
      Otherwise you will get AMP-validation errors  -->

Обратите внимание, что в AMP нам нужно использовать теги <amp-img> </amp-img> вместо тегов <img />. Также я считаю, что вы не можете использовать window.open (), поскольку в AMP разрешены только несколько функций javascript, занесенных в белый список, хотя желаемая функциональность может быть воссоздана с использованием логики AMP.

...