emberjs学习二(ember-data和localstorage_adapter)
准备工作
首先我们加入ember-data
和ember-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-data
和localstorage_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)的更多相关文章
-
emberjs学习一(环境和第一个例子)
code { margin: 0; padding: 0; white-space: pre; border: none; background: transparent; } code, pre t ...
-
ReactJS入门学习二
ReactJS入门学习二 阅读目录 React的背景和基本原理 理解React.render() 什么是JSX? 为什么要使用JSX? JSX的语法 如何在JSX中如何使用事件 如何在JSX中如何使用 ...
-
Hbase深入学习(二) 安装hbase
Hbase深入学习(二) 安装hbase This guidedescribes setup of a standalone hbase instance that uses the local fi ...
-
SpringCloud学习(二):微服务入门实战项目搭建
一.开始使用Spring Cloud实战微服务 1.SpringCloud是什么? 云计算的解决方案?不是 SpringCloud是一个在SpringBoot的基础上构建的一个快速构建分布式系统的工具 ...
-
DjangoRestFramework学习二之序列化组件、视图组件 serializer modelserializer
DjangoRestFramework学习二之序列化组件.视图组件 本节目录 一 序列化组件 二 视图组件 三 xxx 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 序列化组 ...
-
SpringMVC入门学习(二)
SpringMVC入门学习(二) ssm框架 springMVC 在上一篇博客中,我简单介绍了一下SpringMVC的环境配置,和简单的使用,今天我们将进一步的学习下Springmvc的操作. mo ...
-
day 82 Vue学习二之vue结合项目简单使用、this指向问题
Vue学习二之vue结合项目简单使用.this指向问题 本节目录 一 阶段性项目流程梳理 二 vue切换图片 三 vue中使用ajax 四 vue实现音乐播放器 五 vue的计算属性和监听器 六 ...
-
标准Trie字典树学习二:Java实现方式之一
特别声明: 博文主要是学习过程中的知识整理,以便之后的查阅回顾.部分内容来源于网络(如有摘录未标注请指出).内容如有差错,也欢迎指正! 系列文章: 1. 标准Trie字典树学习一:原理解析 2.标准T ...
-
day 90 DjangoRestFramework学习二之序列化组件
DjangoRestFramework学习二之序列化组件 本节目录 一 序列化组件 二 xxx 三 xxx 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 序列化组件 首先按照 ...
随机推荐
-
2015游戏蛮牛——蛮牛杯第四届开发者大赛 创见VR未来开启报名
蛮牛杯启动了,大家开始报名! http://cup.manew.com/ 这不是一篇普通的通稿,别着急忽略它.它是一篇可以让你梦想变现的通稿! 从某一天开始,游戏蛮牛就立志要为开发者服务,我们深知这一 ...
-
sublime-text3 3059基本配置
1.下载安装官方版注册机语言包 参考安装: http://www.xiumu.org/note/sublime-text-3.shtml 2.插件 Package ControlConvertToUT ...
-
HTML字符实体
常用实体符号:
-
Jquery面试题整合
来自棱镜学院-在线IT教育 www.prismcollege.com 一.Jquery測试题 以下哪种不是jquery的选择器?(单选) A.基本选择器 B.后代选择器 C.类选择器 D.进一 ...
-
hihoCoder 1388 Periodic Signal(FFT)
[题目链接] http://hihocoder.com/problemset/problem/1388 [题目大意] 给出A数列和B数列,求下图式子: [题解] 我们将多项式拆开,我们可以得到固定项A ...
-
解决Tomcat启动时项目重复加载问题
前几天一个同学项目要上线,部署到服务器时,因为客户需要通过IP直接可以访问到,所以在server.xml做了如下的配置 导致启动tomcat时候出现一个项目重复加载了两次,很容易就出现了内存溢出. 这 ...
-
ZH奶酪:Ubuntu 14.04配置LAMP(Linux、Apache、MySQL、PHP)
ZH奶酪:Ubuntu 14.04安装LAMP(Linux,Apache,MySQL,PHP) 之前已经介绍过LAMP的安装,这边文章主要讲解一下LAMP的配置. 1.配置Apache (1)调整Ke ...
-
DHCP服务器-DNS服务器-Samba服务器
DHCP服务器 DHCP在管理网络配置方面很有作用,特别是一个当一个网络的规模较大时,使用DHCP可极大的减少 管理员的工作量. DHCP分为两部分:服务端和客户端.服务端负责集中管理可动态分配的IP ...
-
Mysql错误积累001-load data导入文件数据出现1290错误
错误出现情景 在cmd中使用mysql命令,学生信息表添加数据.使用load data方式简单批量导入数据. 准备好文本数据: xueshengxinxi.txt 文件 数据之间以tab键进行分割 ...
-
css高度已知,左右定宽,中间自适应三栏布局
css高度已知,左右定宽,中间自适应三栏布局: <!DOCTYPE html> <html lang="en"> <head> <meta ...