使用 amp-list 的地理定位
简介
如果需要比 amp-geo 扩展提供的更细粒度的地理定位支持,您可以在后端使用地理定位逻辑和 amp-list 实现基于地理位置的功能。这会增加一个额外的 XHR 请求,但您可以使用占位符属性中的骨架布局来减轻负面的用户体验影响。
设置
导入 amp-list
组件...
<script async custom-element="amp-list" src="https://cdn.ampproject.org/v0/amp-list-0.1.js"></script>
...以及 amp-mustache
组件
<script async custom-template="amp-mustache" src="https://cdn.ampproject.org/v0/amp-mustache-0.2.js"></script>
基于地理位置的搜索结果
amp-list
向服务器后端发出请求,该后端执行基于 IP 的地理定位并返回相关的搜索结果。 对于此演示,它调用 API 以获取附近的城市。后端返回 JSON 结果,amp-list
使用 amp-mustache
渲染这些结果。 后端进行两次远程 API 调用(并且还添加 500 毫秒的模拟延迟);为了减轻此延迟对用户体验的影响,我们使用 amp-list
的 placeholder
来布局骨架。
由于我们需要为 amp-list 设置初始固定大小,我们手动计算出每个卡片是 100 + 15px 边距,标题是 16px + 20px 边距
16px + 20px + (5 * (100 + 15px)) = 611px
占位符列表项主要使用 CSS 来绘制骨架元素,如 CSS-Tricks 中所述。 骨架包括一个小的模糊地图,以增加真实感,并且在 <amp-img>
加载实际图像时也使用该地图,以防止删除占位符时出现闪烁。
您位于 {{location}}
- {{#results}}
-
{{placeName}}
{{adminName1}}
{{countryCode}} {{/results}}
您位于
<amp-list class="geolist-preview" width="auto" height="640" layout="fixed-height" noloading src="https://caramel-wolf.glitch.me//location-specific-results.json" binding="no" single-item items=".">
<template type="amp-mustache" id="amp-template-id">
<h3>You are in {{location}}</h3>
<ul class="results">
{{#results}}
<li>
<amp-img alt="{{placeName}} Map" noloading layout="fixed" width="150" height="100" src="https://maps.googleapis.com/maps/api/staticmap?markers={{lat}},{{lng}}&zoom=9&size=150x100&maptype=roadmap&key=AIzaSyByT-0aYa-nEF0gGqJHNpEEK1bus00losI">
</amp-img>
<p>
<strong>{{placeName}}</strong><br>
{{adminName1}}<br>
{{countryCode}}
</p>
</li>
{{/results}}
</ul>
</template>
<div placeholder>
<h3>You are in <span class="placeholder"></span></h3>
<ul class="results">
<li></li><li></li><li></li><li></li><li></li>
</ul>
</div>
</amp-list>
需要进一步解释吗?
如果此页面上的解释没有涵盖您的所有问题,请随时与其他 AMP 用户联系,讨论您的确切用例。
前往 Stack Overflow 一个无法解释的功能?AMP 项目强烈鼓励您的参与和贡献! 我们希望您成为我们开源社区的长期参与者,但我们也欢迎您对您特别感兴趣的问题的一次性贡献。
在 GitHub 上编辑示例-
由 @jamesshannon 撰写