入门指南 获取Ember 概念 对象模型 应用 模板 路由 组件 控制器 模型 视图 枚举 测式 配置Ember.js COOKBOOK 理解Ember.js

发布于 2015-08-18 16:32:24 | 300 次阅读 | 评论: 0 | 来源: 网络整理

仓库可以认为是所有应用加载的记录的一个缓存池。如果应用中的控制器或者路由请求一个记录,当记录已经被缓存时,仓库会立即将其返回。否则仓库必须请求适配器去加载这个记录,这通常就意味着需要通过网络去服务器端去获取该记录。

为了避免一直等待着应用获取记录,可以事先将记录推送到仓库中进行缓存。

这对于事先能预知用户需要获取什么数据的场景尤为有用。当用户点击一个连接,避免等待网络请求完成,Ember.js可以立即渲染新的模板。这能提高应用的实时性。

另外一种情况是在应用保持一个与后端的流式连接的情形。如果一个记录被创建或者修改,可以立即自动更新UI。

推送记录

为了将记录推入仓库,需要调用仓库的push()方法。

例如,假设在应用初次启动时,需要预先加载一些数据到仓库。

可以使用ApplicationRoute来完成这些操作。ApplicationRoute是路由层级中最顶层的路由,其model钩子在应用启动的时候被调用。

 
var attr = DS.attr;

App.Album = DS.Model.extend({
  title: attr(),
  artist: attr(),
  songCount: attr()
});

App.ApplicationRoute = Ember.Route.extend({
  model: function() {
    this.store.push('album', {
      id: 1,
      title: "Fewer Moving Parts",
      artist: "David Bazan",
      songCount: 10
    });

    this.store.push('album', {
      id: 2,
      title: "Calgary b/w I Can't Make You Love Me/Nick Of Time",
      artist: "Bon Iver",
      songCount: 2
    });
  }
});
 
最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务