Ember 载入液体火焰模板

Ember Loading Template with Liquid Fire

我一直在对此进行大量修改,但似乎无法使其正常工作。我希望在等待我对 return.

的模型承诺时显示我的加载模板

我的理解是,默认情况下,如果我有 app/templates/loading.hbs,这个模板将在所有路线上呈现。但是,即使我在路线之间切换时使用了该模板,旧路线仍然显示到模型 returns,此时我的液体火力转换发生,您将被带到下一条路线。

我已经尝试过为每条路线创建嵌套加载模板的各种版本,尝试为加载模板的每条路线创建子路线,甚至弄乱了可用的 beforeModel/afterModel 方法,但我没有进步。这是我在启动之前要跨越的最后一个障碍,我很困惑为什么我不能让它工作。这是我认为相关的一堆代码。

注意:我正在使用 Ember CLI 和 Liquid Fire。目前,我的数据也正在 return 从 am Ember 服务编辑到模型中。

路由器

Router.map(function() {
  this.route('reviews', function() {
    this.route('index', {path: '/'});
    this.route('review', {path: '/:review_id'});
  });
  this.route('movies');
  this.route('about');
});

app/template/loading.hbs

<div class="content-container">
    <h1>Ish be loading</h1>
</div>

最慢模型路线

export default Ember.Route.extend({
    activate() {
        this._super();
        $("html,body").animate({scrollTop:0},"fast");
        $("body").addClass('movies');
    },
    deactivate() {
        $("body").removeClass('movies');
    },
    model() {
        const movies = this.get('movies');
        return movies.getMoviesInAlphOrder();
    },
    afterModel: function() {
        $(document).attr('title', 'Slasher Obscura - Movie Database');
    },
    movies: Ember.inject.service()
});

app.js

App = Ember.Application.extend({
    modulePrefix: config.modulePrefix,
    podModulePrefix: config.podModulePrefix,
    Resolver,
    ...
});
loadInitializers(App, config.modulePrefix);

服务方式

sortReviewsByDateDesc(arr) {
        return arr.slice().sort(function (a, b) {
            return a.review.date > b.review.date ? -1 : 1;
        });
    },
    getSetAmountOfMovies(num, arr) {
        const movieList = arr ? null : this.getMovies();
        const trimmedList = arr ? arr.slice(0, num) : movieList.slice(0, num);        
        return trimmedList;
    },
    setFirstReviewToFeatured(arr) {
        arr[0].isFeatured = true;
        return arr;
    },
    getLatestReviews(num) {
        const movieList = this.getMovies();
        const reviewList = movieList.filterBy('review');
        const indexList = this.sortReviewsByDateDesc(reviewList);
        const latestList = this.getSetAmountOfMovies(num, indexList);
        return this.setFirstReviewToFeatured(latestList);
    },
    getMoviesInAlphOrder() {
        const movieList = this.getMovies();
        let lowerCaseA, lowerCaseB;
        return movieList.sort(function(a, b) {
            lowerCaseA = a.title.toLocaleLowerCase();
            lowerCaseB = b.title.toLocaleLowerCase();
            return lowerCaseA.localeCompare(lowerCaseB);
        });
    },
getMovies() {
        return [{
            id: 1,
            title: '303 Fear Faith Revenge',
            year: "1999",
            imdb: "tt0219682",
            youtube: "iFV1qaUWemA"
        }
...
]

我已经阅读了 Ember 网站上的文档以及各种其他 Google 资源,但似乎无法弄清楚为什么我的加载模板根本没有呈现。任何帮助都是极好的!谢谢!

当您的模型挂钩 returns 需要很长时间才能解决的承诺时触发加载模板,但是,您的模型挂钩未返回承诺。

model() {
  const movies = this.get('movies');

  return movies.getMoviesInAlphOrder();
}

getMoviesInAlphOrder 正在返回一个同步数组。进一步与您交谈后发现,您已经为这个数组客户端预先填充了 540 个项目,所以这里的问题是加载模板不仅没有等待的承诺,而且即使有无论如何它都会立即解决。

您的时间延迟很可能是由于呈现一长串项目而导致的性能问题。有几个 Ember 插件可以帮助解决这个问题,包括我自己的一个:https://github.com/runspired/smoke-and-mirrors

或者/此外,您可能需要考虑 "chunking" 将数组分成更小的位并一次渲染 25-50,或者设置一些分页。