emberjs学习二(ember-data和localstorage_adapter)

准备工作

首先我们加入ember-dataember-localstorage-adapter两个依赖项,使用bower install安装这两个插件。如下

"dependencies": {
"jquery": "~1.9.1",
"ember": "~1.13.10",
"handlebars":"~1.3.0",
"ember-data":"~1.13.11",
"ember-localstorage-adapter":"latest"
}

然后就可以开始我们今天的例子了,我们今天要做的事情和【初学emberjs】并没有太多的不一样,只是之前的数据源采用的数组,而且数据在刷新后就没了,而今天要做的就是把数组换成emberjs的数据模型,然后保存到localstorage中,所以预览效果的话要浏览器支持localstorage.

ok,还是新建一个.html页面和一个app.js文件,然后在html中引入js

<script type="text/javascript" src="../../bower_components/jquery/jquery.min.js"></script>
<script type="text/javascript" src="../../bower_components/handlebars/handlebars.min.js"></script>
<script type="text/javascript" src="../../bower_components/ember/ember-template-compiler.js"></script>
<script type="text/javascript" src="../../bower_components/ember/ember.min.js"></script>
<script type="text/javascript" src="../../bower_components/ember-data/ember-data.min.js"></script>
<script type="text/javascript" src="../../bower_components/ember-localstorage-adapter/localstorage_adapter.js"></script>
<script type="text/javascript" src="js/app.js"></script>

这里比之前多引用了ember-datalocalstorage_adapter

我们试想的场景还是一个初始的列表,然后我们对它进行增删改,这些改动都同步到本地,刷新也存在。我们先把列表显示出来:

<script type="text/x-handlebars" id="index">
<ol>
{{#each model}}
<li>{{title}} <button {{action "del"}}>删除</button></li>
{{/each}}
</ol>
{{outlet}}
</script>

然后我们在index的Route中返回一个store.

App.IndexRoute = Ember.Route.extend({
model: function() {
return this.store.find('test');
}
});

它的意思是在store里查找一个命名空间叫test的数据对象模型,它里面有一个content的属性,就是对应的数据集了,所以在上面的each中我们可以{{#each content}}或者{{#each controller}}(不推荐).

一开始是没有数据的,我们再上面的模板里再加一个输入框和一个添加按钮:

{{input value=title}}
<button {{action "add"}}>添加</button>

这里的input绑定了一个title的属性,老的写法是valueBinding="title",但新版似乎并不推荐这么写了,这个title就对应到了controller里的属性了,button上加了一个add的action.

App.IndexController = Ember.ArrayController.extend({
title:null,
actions:{
add:function(){
}
});

好,我们还要为刚才的store注册一个适配器,emberjs有一个默认的适配器RESTAdapter,它是用为提交网络请求的,就是在你增删改的时候都会向服务器提交ajax返回json,但这次我们并不需要它,我们要用到的是ember-localstorage-adapter

/** Ember Data **/
App.Test = DS.Model.extend({
title: DS.attr('string'),
desc: DS.attr('string')
});
App.ApplicationAdapter = DS.LSAdapter.extend({
namespace: 'test'
});

这里我们建了一个有两个字段的模型,然后加了一个命名空间叫test的适配器,好,我们接着actions的add操作编写代码,要新增一条记录可以使用store.createRecord方法。

actions:{
add:function(){
console.log(this.get('content'))
console.log(this.get('title'))
var newRecord= this.store.createRecord('test');
newRecord.set('title',this.get('title'));
newRecord.save();
}
}

我们在test创建一个记录,然后set它的值,这里还有另外一种写法,就是使用createRecord的第二参数,传入新增的对象

var newRecord= this.store.createRecord('test',{
title:this.get('title')
});

打开网页,我们试下效果

然后我们按照上节的例子加入删除的action

del:function(record){
this.store.deleteRecord(r);
r.save();
}

修改的操作和【初学emberjs】里的类似,这里就不重复贴了,我会在后面的源码中加入这个代码功能。

        update: function() {
var content = this.get('content');
content.save();
}
App.InfoRoute = Ember.Route.extend({
model: function(arg) {
console.log(arg)
return this.store.find('test', arg.id);
}
});

本文的源码地址:https://github.com/tianxiangbing/emberjs-test/tree/master/example/test2

本文的demo案例地址:http://www.lovewebgames.com/emberjs/example/test2/index.html

emberjs学习二(ember-data和localstorage_adapter)的更多相关文章

  1. emberjs学习一(环境和第一个例子)

    code { margin: 0; padding: 0; white-space: pre; border: none; background: transparent; } code, pre t ...

  2. ReactJS入门学习二

    ReactJS入门学习二 阅读目录 React的背景和基本原理 理解React.render() 什么是JSX? 为什么要使用JSX? JSX的语法 如何在JSX中如何使用事件 如何在JSX中如何使用 ...

  3. Hbase深入学习(二) 安装hbase

    Hbase深入学习(二) 安装hbase This guidedescribes setup of a standalone hbase instance that uses the local fi ...

  4. SpringCloud学习(二):微服务入门实战项目搭建

    一.开始使用Spring Cloud实战微服务 1.SpringCloud是什么? 云计算的解决方案?不是 SpringCloud是一个在SpringBoot的基础上构建的一个快速构建分布式系统的工具 ...

  5. DjangoRestFramework学习二之序列化组件、视图组件 serializer modelserializer

      DjangoRestFramework学习二之序列化组件.视图组件   本节目录 一 序列化组件 二 视图组件 三 xxx 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 序列化组 ...

  6. SpringMVC入门学习(二)

    SpringMVC入门学习(二) ssm框架 springMVC  在上一篇博客中,我简单介绍了一下SpringMVC的环境配置,和简单的使用,今天我们将进一步的学习下Springmvc的操作. mo ...

  7. day 82 Vue学习二之vue结合项目简单使用、this指向问题

    Vue学习二之vue结合项目简单使用.this指向问题   本节目录 一 阶段性项目流程梳理 二 vue切换图片 三 vue中使用ajax 四 vue实现音乐播放器 五 vue的计算属性和监听器 六 ...

  8. 标准Trie字典树学习二:Java实现方式之一

    特别声明: 博文主要是学习过程中的知识整理,以便之后的查阅回顾.部分内容来源于网络(如有摘录未标注请指出).内容如有差错,也欢迎指正! 系列文章: 1. 标准Trie字典树学习一:原理解析 2.标准T ...

  9. day 90 DjangoRestFramework学习二之序列化组件

      DjangoRestFramework学习二之序列化组件   本节目录 一 序列化组件 二 xxx 三 xxx 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 序列化组件 首先按照 ...

随机推荐

  1. Android开发之时间日期1

     对于手机的时间日期设置估计大家一定都不陌生吧,今天做了一个关于时间日期设置的小例子,其中遇到一个问题,求指导,如何使设置的时间日期和手机系统同步?还望高手指点一二. 先不说这个了,分享一下我的小例子 ...

  2. Deep learning:四十(龙星计划2013深度学习课程小总结)

    头脑一热,坐几十个小时的硬座北上去天津大学去听了门4天的深度学习课程,课程预先的计划内容见:http://cs.tju.edu.cn/web/courseIntro.html.上课老师为微软研究院的大 ...

  3. S Gallery – 很有特色的响应式 jQuery 相册插件

    S Gallery 是一款响应式的 jQuery 相册插件.使用了 HTML5 全屏 API 以及 CSS3 动画 和 CSS3 转换,所以只能在支持这些功能的浏览器中使用. 这款插件它有一个特色功能 ...

  4. SQL Server 2014新特性——基数评估(白皮书阅读笔记)

    基数评估 目录 基数评估 说明 基数评估准确的重要性 模型假设 启用新的基数评估 验证基数评估的版本 在迁移到新的基数评估前要测试 校验基数评估 偏差问题 需要手动处理的变化 避免因为新的CE造成性能 ...

  5. Eclipse快捷键(转)

    Ctrl+1 快速修复(最经典的快捷键,就不用多说了)Ctrl+D: 删除当前行 Ctrl+Alt+↓ 复制当前行到下一行(复制增加)Ctrl+Alt+↑ 复制当前行到上一行(复制增加)Alt+↓ 当 ...

  6. java设计模式(六)--观察者模式

    转载:设计模式(中文-文字版) 目录: 简单目标任务实现 观察者模式介绍 观察者模式代码实现 观察者模式是JDK中使用最多的模式之一,非常有用.我们也会一并介绍一对多关系,以及松耦合(对,没错,我们说 ...

  7. JVM之类加载器下篇

    除了自定义的类加载之外,jvm存在三种类加载器,并以一种父委托的加载机制进行加载. --启动类加载器,又称根加载器,是一个native的方法,使用c++实现.在java中我们用null标识,用于加载j ...

  8. 前端构建:Source Maps详解

    一.前言 当使用CoffeeScript.ClojureScript编写前端脚本时,当使用Less.Sacc编写样式规则时,是否觉得调试时无法准确找到源码位置呢?当使用jquery.min.js等经压 ...

  9. Moon.Orm 5.0 (MQL版) 驱动开发方案

    Moon.Orm 5.0 (MQL版) 配置说明 这一文中说明了如何配置,如何写自己的驱动.要写自己的驱动方法就是继承基类Db, Db的类结构,点击查看

  10. 【Swift学习】Swift编程之旅---集合类型之字典(八)

    字典是一种存储相同类型多重数据的存储器.每个值(value)都关联独特的键(key),键作为字典中的这个值数据的标识符.和数组中的数据项不同,字典中的数据项并没有具体顺序. 字典写作Dictionar ...