bLazy 图像延迟加载无法与 ionic2 结合使用

bLazy image lazyloading not working in combination with ionic2

我目前正在尝试将 bLazy 延迟加载脚本与 angular2 和 ionic2 结合使用。

仅将 javascript 与 HTML 一起使用就像一个魅力和预期的那样:

<html>
<head>
<script src="https://cdnjs.cloudflare.com/ajax/libs/blazy/1.6.2/blazy.min.js"></script>
</head>
<body>
<script>
    // Example
    var bLazy = new Blazy({
        src: 'blazy-data' // Default is data-src
    });
</script>

<style>
    .b-lazy {
        -webkit-transition: opacity 500ms ease-in-out;
        -moz-transition: opacity 500ms ease-in-out;
        -o-transition: opacity 500ms ease-in-out;
        transition: opacity 500ms ease-in-out;
        max-width: 100%;
        opacity: 0;
    }
    .b-lazy.b-loaded {
        opacity: 1;
    }
    .imgbg {
        background-color:#b0b0b0;
        max-width: 400px;
        padding: 2px;
        border-color: #fff;
        border-style: solid;
    }
</style>

<div class="imgbg"><img class="b-lazy" src="" blazy-data="http://lorempixel.com/400/400/abstract" border="1" width="400" height="400" /></div>
<div class="imgbg"><img class="b-lazy" src="" blazy-data="http://lorempixel.com/400/400/fashion" border="1" width="400" height="400" /></div>
<div class="imgbg"><img class="b-lazy" src="" blazy-data="http://lorempixel.com/400/400/city" border="1" width="400" height="400" /></div>
<div class="imgbg"><img class="b-lazy" src="" blazy-data="http://lorempixel.com/400/400/sports" border="1" width="400" height="400" /></div>
<div class="imgbg"><img class="b-lazy" src="" blazy-data="http://lorempixel.com/400/400/people" border="1" width="400" height="400" /></div>

</body>
</html>

这显示了延迟加载图像的占位符,一旦它们进入视口,就会加载并显示。 (与 jsfiddle here 相同的代码)

在 ionic2 应用程序中使用相同的 DIV 时,延迟加载不起作用。 请注意,我已经使用了关于将 bLazy 与 angular.

一起使用的文档中提到的机制

它只是在第一次初始化后不加载图像。所以我认为这可能是一个时间问题,但即使使用按钮调用 bLazy 的 revalidate 方法,它也只加载视口内的图像,所有其他图像都被忽略。

请查看此 plunkr 示例:https://plnkr.co/edit/5LoBQ389PQv4AlBTlbjw?p=preview

有人知道这个问题的解决方法或如何正确地将 bLazy 与 ionic2 一起使用吗?

提前致谢。

你这里有两个问题:

1) 如果你不指定容器,bLazy 只监听 window 上的滚动事件 - 在这种情况下你需要它来监听 scroll-content 上的滚动事件。

2) 时间安排有些奇怪。我不是 100% 确定是什么和为什么,但下面的解决方案解决了它。

/* ... */

export class HomePage {

  /* ... */

  ionViewLoaded() {
    this.bLazy = new Blazy({ 
      src: 'blazy-data', // Default is data-src
      container: 'scroll-content'
    });
  }

  ionViewDidEnter() {
    this.bLazy.revalidate();
  }

  constructor(private nav: NavController) {
  }

  /* ... */

}

ionViewLoadedionViewDidEnterIonic 2 Lifecycle events

在我看来,ionViewLoaded 理论上应该足够了,因为它会在页面准备就绪时调用。但由于不知何故它没有,我们只需重新验证 bLazy 成为活动页面。