摘要:文章来源发布项目,加入功能接着前面三篇环境搭建以及使用创建第一个静态页面引入计算属性动态内容模型,保存数据到数据库应用发布发布方式一发布的详细教程请看。执行如下命令发布项目。
文章来源:发布项目,加入CRUD功能
接着前面三篇:
环境搭建以及使用Ember.js创建第一个静态页面
引入计算属性、action、动态内容
模型,保存数据到数据库
应用发布发布方式一
发布的详细教程请看guide on firebase。执行如下命令发布项目。
npm install -g firebase-tools ember build --prod firebase login firebase init
执行命令过程需要输入一个public的目录,输入dist后按enter。更新firebase.json的内容。
{
"firebase": "YOUR-APP-NAME",
"public": "dist",
"rewrites": [{
"source": "**",
"destination": "/index.html"
}]
}
遗憾的是在我电脑上一直提示没有firebase命令,即使我已经安装了这个插件也不行。
发布方式二
由于上述方式无法发布想到到firebase,所以使用最原始的发布方式,使用ember命令打包项目。然后自己把项目部署到服务器上。
打包项目
打包项目使用命令ember build --prod,等到命令执行完毕后再项目的dist目录下的所有文件即使打包后的项目文件。
复制打包后的文件到服务器上
得到打包后的文件后可以直接把这些文件复制到服务器上运行,比如复制到tomcat的webapps目录下。
运行项目
复制到服务器之后启动服务器,直接访问:http://localhost:8080
增加删除、修改功能修改项目的library列表页面,增加删除和修改功能。
## List{{#each model as |library|}}{{/each}}### {{library.name}}Address: {{library.address}} Phone: {{library.phone}}
相比原来的代码增加了一个连接和一个按钮,分别用于编辑和删除library信息。相对于需要增加一个路由libraries/edit和一个处理的动作{{action "deleteLibrary"}}。
如果此时运行http://localhost:4200/libraries会出现错误,因为还没定义路由libraries/edit和action。别急,先一步步来,下面先增加一些css样式。
# app/styles/app.scss
@import "bootstrap";
body {
padding-top: 20px;
}
html {
overflow-y: scroll;
}
.library-item {
min-height: 150px;
}
创建路由libraries/edit和路由对应的模板
简单起见直接使用Ember CLI命令创建,就不手动创建了。执行命令:ember g route libraries/edit创建路由和路由对应的模板。
创建完成之后还需要手动修改app/router.js文件,内容如下:
// app/router.js
import Ember from "ember";
import config from "./config/environment";
var Router = Ember.Router.extend({
location: config.locationType
});
Router.map(function() {
this.route("about");
this.route("contact");
this.route("admin", function() {
this.route("invitation");
this.route("contact");
});
this.route("libraries", function() {
this.route("new");
// :library_id是一个动态段,会根据实际的URL变化
this.route("edit", { path: "/:library_id/edit" });
});
});
export default Router;
注意this.route("edit", { path: "/:library_id/edit" });这行代码的设置。与普通的路由稍有不同这里增加了一个参数,并且参数内使用path设定路由渲染之后edit会被/:library_id/edit替换。
编译、渲染之后的URL格式为http://example.com/libraries/1234/edit其中:library_id这是一个动态段,这个URL例子中动态段library_id的值就是1234,并且可以在路由类中获取这个动态段的值。
更多有关动态段的介绍请看Ember.js 入门指南之十三{{link-to}} 助手或者Dynamic Segments。
配置完路由之后修改路由libraries/edit.js的代码。
// app/routes/libraries/edit.js
import Ember from "ember";
export default Ember.Route.extend({
model(params) {
// 获取动态段library_id的值
return this.store.findRecord("library", params.library_id);
},
actions: {
saveLibrary(newLibrary) {
newLibrary.save().then(() => this.transitionTo("libraries"));
},
willTransition(transition) {
let model = this.controller.get("model");
if (model.get("hasDirtyAttributes")) {
let confirmation = confirm("Your changes haven"t saved yet. Would you like to leave this form?");
if (confirmation) {
model.rollbackAttributes();
} else {
transition.abort();
}
}
}
}
});
代码this.store.findRecord("library", params.library_id);的意思是根据模型的id属性值查询某个记录,其中library_id就是动态段的值,这个值是Ember解析URL得到的。正如前面所说:http://example.com/libraries/1234/edit这个URL动态段的值就是1234。
Ember会自动根据URL的格式解析得到。并且可以在路由类中获取。默认情况下动态段的值是数据的id值。代码中的另外两个方法saveLibrary()和willTransition()在前一篇文章模型,保存数据到数据库已经介绍过,在此不再赘述。
方法willTransition()的作用就是:当用户修改了数据之后没有点击保存就离开页面时会提示用户是否确认不保存就离开页面!通过控制器中的属性hasDirtyAttributes判断页面的值是否发生了变化。方法rollbackAttributes()会重置model中的值。方法abourt()可以阻止路由的跳转,有关路由的跳转请看Ember.js 入门指南之二十四终止与重试路由跳转。从new.hbs复制代码到edit.hbs,然后在稍加修改。
## Edit Library{{input type="text" value=model.name class="form-control" placeholder="The name of the Library"}}{{input type="text" value=model.address class="form-control" placeholder="The address of the Library"}}{{input type="text" value=model.phone class="form-control" placeholder="The phone number of the Library"}}
等待项目重启完成,进入到修改界面,任意修改界面上的数据,不点击保存然后任意点击其他链接会弹出提示,询问你是否确认离开页面。操作步骤如下截图。
注意:看浏览器的URL。首页模板代码{{#link-to "libraries.edit" library.id class="btn btn-success btn-xs"}}Edit{{/link-to}}中的路由libraries.edit渲染之后会得到形如libraries/xxx/edit的URL,其中xxx就是动态段的值。
弹出提示信息。如果点击取消会停留在当前页面,如果选中确定会跳转到首页(因为我点击的是菜单的Home)。
成功保存了修改的内容。到此实现了修改功能。
实现删除功能删除功能比修改更加简单,直接在方法deleteLibrary里根据id属性值删除数据即可。id属性值已经在模板页面作为参数传递到方法中。直接获取即可。
// app/routes/libraries/index.js
import Ember from "ember";
export default Ember.Route.extend({
model() {
return this.store.findAll("library");
},
actions: {
// 删除一个library记录
deleteLibrary(library) { //参数library已经在模板中传递过来
let confirmation = confirm("Are you sure?");
if (confirmation) {
library.destroyRecord();
}
}
}
});
模板中是这样调用删除方法的,看到参数library了吧,这个参数就是一个library模型对象。
可以直接调用方法destroyRecord()实现删除数据。
选中确定之后删除就会立刻删除,列表上的数据也会动态更新。
家庭作业参照library的功能实现contact的删除与修改。
新建路由和模板ember g route admin/contact/edit ember g template admin/contact/index修改router.js,增加配置
// app/router.js
this.route("admin", function() {
this.route("invitation");
this.route("contact", function() {
this.route("edit", { path: "/:contact_id/edit" });
});
});
省略其他内容,仅仅列出修改部分。
复制admin/contact.hbs的内容到admin/contact/index.hbs,然后空admin/contact.hbs再在文件内添加{{outlet}}admin/contact.hbs
{{outlet}}
admin/contact/index.hbs
{{! app/templates/admin/contact/index.hbs}}
# Contacts
| ID | Message | Operation | |
|---|---|---|---|
| {{contact.id}} | {{contact.email}} | {{contact.message}} | {{#link-to "admin.contact.edit" contact.id class="btn btn-success btn-xs"}}Edit{{/link-to}} |
增加删除、修改按钮。
复制app/templates/contact.hbs到admin/contact/edit.hbs并做修改admin/contact/edit.hbs
{{! app/templates/admin/contact/edit.hbs}}
修改routes/context.js
// app/routes/contact.js
import Ember from "ember";
export default Ember.Route.extend({
model: function() {
return this.store.findAll("contact");
},
actions: {
deleteContact: function(contact) {
let confirmation = confirm("Are you sure?");
if (confirmation) {
contact.destroyRecord();
}
}
}
});
修改app/routes/admin/contact/edit.js
// app/routes/admin/contact/edit.js
import Ember from "ember";
export default Ember.Route.extend({
model(params) {
// 获取动态段library_id的值
return this.store.findRecord("contact", params.contact_id);
},
actions: {
saveContact(newContact) {
newContact.save().then(() => this.transitionTo("admin.contact"));
},
willTransition(transition) {
let model = this.controller.get("model");
if (model.get("hasDirtyAttributes")) {
let confirmation = confirm("Your changes haven"t saved yet. Would you like to leave this form?");
if (confirmation) {
model.rollbackAttributes();
} else {
transition.abort();
}
}
}
}
});
运行结果不再截图列出,请读者自行试验。
为了照顾懒人我把完整的代码放在GitHub上,可以拿来做参照。博文经过多次修改,博文上的代码与github代码可能有出入,不过影响不大!如果你觉得博文对你有点用,请在github项目上给我点个star吧。您的肯定对我来说是最大的动力!!
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/79537.html
摘要:发布,海量图表供你选择,丰富模板一键创建,提供多种垂直领域模板,快速创建项目,支持风格切换,满足个性化需求轻松操作页面管理,海量物料自由搭配,页面组合可视化操作更得心应手开发调试一体化,集成运行环境零配置运行,开箱即用。 Iceworks 2.7.0 发布,海量图表供你选择 Iceworks,丰富模板一键创建,提供多种垂直领域模板,快速创建项目,支持风格切换,满足个性化需求;轻松操作页...
摘要:发布,海量图表供你选择,丰富模板一键创建,提供多种垂直领域模板,快速创建项目,支持风格切换,满足个性化需求轻松操作页面管理,海量物料自由搭配,页面组合可视化操作更得心应手开发调试一体化,集成运行环境零配置运行,开箱即用。 Iceworks 2.7.0 发布,海量图表供你选择 Iceworks,丰富模板一键创建,提供多种垂直领域模板,快速创建项目,支持风格切换,满足个性化需求;轻松操作页...
摘要:理解协议协议只能通过客户端发起请求来与客户端进行通讯这是一个缺陷。与协议有着良好的兼容性。以下的表格内容显示数据局里的内容,每秒局部刷新一次表格内容。欢迎大侠能够给我的项目提出修改意见,先行感谢源码下载参考基于的操作教程阮一峰 Flask 作为一个全栈架构,如果你只会 python,而不懂 javascript 的前端知识,似乎是无法支撑起你的 web 梦想的,比如,一个简单的页面 局...
摘要:是一套基于和的表格组件。将的功能进行了封装,并增加了表格的增删改查数据校验表格内编辑等常用的功能。大部分功能可由配置实现,在实现并扩展了表格组件功能的同时,降低了开发难度,减少了代码量,大大简化了开发流程。 D2-Crud 是一套基于Vue.js 2.2.0+ 和 Element UI 2.0.0+ 的表格组件。D2-Crud 将 Element 的功能进行了封装,并增加了表格的增删改...
阅读 2979·2021-11-24 09:39
阅读 2365·2021-11-24 09:38
阅读 906·2021-11-22 14:44
阅读 2179·2021-11-18 10:02
阅读 3501·2021-11-18 10:02
阅读 1473·2021-10-14 09:43
阅读 6144·2021-09-29 09:35
阅读 835·2021-07-30 15:30