AMP
  • 网站

显示更多按钮

简介

这是一个示例,展示如何实现“显示更多”设计模式。“显示更多”是一种常见的电子商务类别页面设计模式,用于通过用户交互触发延迟加载更多内容。

设置

此外,必须在标头中导入使用的 AMP 组件。我们使用 amp-list 显示产品列表

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

我们使用 amp-bind 动态更改 amp-list 的 src

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

我们使用 amp-form 在用户交互后调用以获取更多产品

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

我们使用 amp-mustache 渲染 amp-list 内容

<script async custom-template="amp-mustache" src="https://cdn.ampproject.org/v0/amp-mustache-0.2.js"></script>

如何实现显示更多按钮

您可以使用 amp-list 并将额外的 load-more 属性设置为选项 manual 来实现显示更多按钮。可选的 load-more-bookmark 属性指定返回数据中的一个字段名,该字段名将给出要加载的下一项的 url。如果未指定,amp-list 会期望响应对象将 load-more-src 字段设置为要加载的下一个 url。

FALLBACK
占位符
错误 结束
<amp-list width="auto" height="332" layout="fixed-height" src="/documentation/examples/api/photo-stream?items=3&left=3" binding="refresh" load-more="manual" load-more-bookmark="next">
  <template type="amp-mustache">
    <div class="list-item">
      <amp-img src="{{imageUrl}}" width="100" height="100">
      </amp-img>
      <p>{{title}}</p>
    </div>
  </template>
  <div fallback>
    FALLBACK
  </div>
  <div placeholder>
    PLACEHOLDER
  </div>
  <amp-list-load-more load-more-failed>
    ERROR
  </amp-list-load-more>
  <amp-list-load-more load-more-end>
    END
  </amp-list-load-more>
</amp-list>

使用 amp-list 和 amp-bind 显示更多

您还可以通过使用 amp-listamp-bind 手动实现显示更多按钮,其中 amp-list src 数据绑定到 amp-state 元素的值。这里我们使用两个 amp-statephotos 使用与 amp-list 相同的 json src,因此最初将包含相同的项目列表...

<amp-state id="photos" src="/documentation/examples/api/photo-stream?items=3&left=3">
</amp-state>

... 而 id 为 productamp-state 仅用于实现显示更多逻辑,我们允许用户点击 3 次。

<amp-state id="product">
  <script type="application/json">
  {
    "moreItemsPageIndex": 2,
    "hasMorePages": true
  }
  </script>
</amp-state>

我们将 amp-listsrc 属性绑定到包含产品的 amp-state 对象

作为 src 的该组件。我们还基于以下内容动态更改 amp-list 的高度

项目数量(每个项目的高度为 108px)。

<amp-list src="/documentation/examples/api/photo-stream?items=3&left=3" [src]="photos.items" binding="refresh" layout="fixed-height" width="auto" height="332" [height]="photos.items.length * 108 + 8">
  <template type="amp-mustache">
    <div class="list-item">
      <amp-img src="{{imageUrl}}" width="100" height="100">
      </amp-img>
      <p>{{title}}</p>
    </div>
  </template>
</amp-list>

显示更多按钮通过一个表单实现,该表单在 submit-success 事件上触发页面更新。

然后,我们使用 concat 函数将表单结果合并到 amp-state 已加载的项目中。

<form method="GET" action="/documentation/examples/api/photo-stream" action-xhr="/documentation/examples/api/photo-stream" target="_top" on="submit-success: AMP.setState({
        photos: {
          items: photos.items.concat(event.response.items)
        },
        product: {
          moreItemsPageIndex: product.moreItemsPageIndex - 1,
          hasMorePages: !!event.response.next
        }
      });">
  <input type="hidden" name="items" value="3">
  <input type="hidden" name="left" value="2" [value]="product.moreItemsPageIndex">
  <input type="submit" value="Show more" [hidden]="!product.hasMorePages">
</form>
需要进一步解释?

如果此页面上的解释没有涵盖您的所有问题,请随时联系其他 AMP 用户以讨论您的确切用例。

前往 Stack Overflow
一个无法解释的功能?

AMP 项目强烈鼓励您的参与和贡献!我们希望您能成为我们开源社区的长期参与者,但我们也欢迎您为自己特别热衷的问题做出一次性贡献。

在 GitHub 上编辑示例