sails框架的学习指南


Posted in Javascript onDecember 22, 2014

上周通过搭建CMS系统接触到了sails框架,知道一些ORM的概念。这周开始深入后台数据交互,发现twenty框架的数据结构在sails上又设计了一番(比如node、category),不得不说师哥就是厉害。不过复杂度也提高了。而我在DTree项目中的任务就是使用sails来进行业务流程和数据库的交互。这周接下来的时间就是使用sails了。

sails简介

sails如同ruby on rails一样,也是一种为了使web开发变得简单的框架。就我这段时间的了解,其完全继承Express&Socket.io的一些API,并且使用了waterline(ORM)进行统一地数据库交互,使得可以在不同的数据库环境中无需直接修改代码即可完成CRUD操作;与backbone框架同步前后端的数据 ,使用policies中间件来进行安全验证交互 自身的blueprints在前后台中无需码一行即可通过RESTfull API进行数据交互。

Socket.io & Express

前端时间学习过这两样东西,一个是websock通信,一个是处理HTTP的请求。sails并没有从新设计而是直接使用这两个工具来处理这些功能,在学习成本上减少了许多。Socket.io在服务器和客户端两边触发消息、监听消息并相应作出操作。

 `

 //服务器端

 io.sockets.on("connection", function(sock){

 sock.emit("normalMessage",{a:"c"});

 });

 //客服端

 sock.on("normalMessage", function(json){...});

 `

Express的作用就在于路由操作,比如app.get('/login', function(req, res){});。
Sails Blueprints & Backbone
在web开发中,CRUD是一类相似操作,比如在http中get/post,数据库中的select/insert这类。sails的blueprint API和js的backbone框架都使用一类统一的函数(比如findOne),使得程序在建立了model和相应的controller时,内在逻辑就已经建立。比如常用的users model在sails就自建了controller来进行users的数据传递和存储。我们需要注意的只有文件名的规范和业务流程即可。如果你要覆盖(重载)原有方法也是可以的。当我们在config文件夹中的routes设置好action和controller之后,在对应的controller中可以添加自己需要的功能。

Waterline
sails这个依赖包的API是用来与数据库交互的,比如create()、findOne()、update()等,正如前面所说,我们无需在意不同的数据库工具直接统一调用这些方法即可。比如输入数据时

`

Users.create({username: username, password: password}).exec(function(error, user) {

 if (error) {

  res.send(500, {error: "DB Error"});

 } else {

  req.session.user = user;

  res.send(user);

 }

`

系统默认的是本地文件系统保存数据,我们如果需要选择mysql或者mongoDB。只需在配置文件中修改一下,选择数据库的adapter就能进行数据交互。

Policies

应用于controller上的中间件,在http请求发出之前运行。可以实现身份控制,比如你只有登录才能进行接下来的动作。

`

if(req.session.user){

    var action = req.options.action;

    if(action == "create"){

     req.body.userId = req.session.user.id;

        req.body.username = req.session.user.username;

    }

    next();

}else{

    res.send("You Must Be Logged In", 403);

}

`

next

sails成功上手,不过还要在这个上面多下功夫。把基础打牢才好实现具体需求。所以接下来还要继续学习,多找例程深入学习sails,也要知道这个框架的局限性。

Javascript 相关文章推荐
一段利用WSH获取登录时间的jscript代码
May 11 Javascript
TimergliderJS 一个基于jQuery的时间轴插件
Dec 07 Javascript
JavaScript控制table某列不显示的方法
Mar 16 Javascript
js获取图片宽高的方法
Nov 25 Javascript
js编写贪吃蛇的小游戏
Aug 24 Javascript
Angular开发者指南之入门介绍
Mar 05 Javascript
angularJs-$http实现百度搜索时的动态下拉框示例
Feb 27 Javascript
node.js自动上传ftp的脚本分享
Jun 16 Javascript
Node.js 使用request模块下载文件的实例
Sep 05 Javascript
TensorFlow.js 微信小程序插件开始支持模型缓存的方法
Feb 21 Javascript
使用Ajax实现无刷新上传文件
Apr 12 Javascript
vue递归实现树形组件
Jul 15 Vue.js
了不起的node.js读书笔记之mongodb数据库交互
Dec 22 #Javascript
javascript动态创建及删除元素的方法
Dec 22 #Javascript
了不起的node.js读书笔记之例程分析
Dec 22 #Javascript
了不起的node.js读书笔记之node的学习总结
Dec 22 #Javascript
了不起的node.js读书笔记之node.js中的特性
Dec 22 #Javascript
jQuery+ajax中getJSON() 用法实例
Dec 22 #Javascript
IE8中动态创建script标签onload无效的解决方法
Dec 22 #Javascript
You might like
PHP面向对象编程快速入门
2006/12/14 PHP
PHP编程中的Session阻塞问题与解决方法分析
2017/08/07 PHP
PHP实现的日历功能示例
2018/09/01 PHP
jQuery弹出层插件简化版代码下载
2008/10/16 Javascript
jQuery EasyUI API 中文文档 - Documentation 文档
2011/09/29 Javascript
event.currentTarget与event.target的区别介绍
2012/12/31 Javascript
js获取url参数值的两种方式
2013/09/10 Javascript
jQuery简单实现banner图片切换
2014/01/02 Javascript
css+js实现部分区域高亮可编辑遮罩层
2014/03/04 Javascript
js网页右下角提示框实例
2014/10/14 Javascript
jquery操作select方法汇总
2015/02/05 Javascript
jQuery超赞的评分插件(8款)
2015/08/20 Javascript
javascript同步服务器时间和同步倒计时小技巧
2015/09/24 Javascript
jQuery事件绑定用法详解(附bind和live的区别)
2016/01/19 Javascript
javascript点击按钮实现隐藏显示切换效果
2016/02/03 Javascript
jQuery封装的屏幕居中提示信息代码
2016/06/08 Javascript
JS递归遍历对象获得Value值方法技巧
2016/06/14 Javascript
使用Javascript监控前端相关数据的代码
2016/10/27 Javascript
深入理解vue中的$set
2017/06/01 Javascript
angular之ng-template模板加载
2017/11/09 Javascript
node微信开发之获取access_token+自定义菜单
2019/03/17 Javascript
vue 内联样式style中的background用法说明
2020/08/05 Javascript
基于vue-simple-uploader封装文件分片上传、秒传及断点续传的全局上传插件功能
2021/02/23 Vue.js
跟老齐学Python之有容乃大的list(1)
2014/09/14 Python
Python基于贪心算法解决背包问题示例
2017/11/27 Python
Python with用法:自动关闭文件进程
2019/07/10 Python
解决python打开https出现certificate verify failed的问题
2020/09/03 Python
python中random.randint和random.randrange的区别详解
2020/09/20 Python
CSS3之2D与3D变换的实现方法
2019/01/28 HTML / CSS
css3实现动画的三种方式
2020/08/24 HTML / CSS
世界上最大的字体市场:MyFonts
2020/01/10 全球购物
C++是不是类型安全的
2014/02/18 面试题
cf收人广告词
2014/03/14 职场文书
歌唱比赛策划方案
2014/06/06 职场文书
乡镇干部党的群众路线教育实践活动个人对照检查材料
2014/09/24 职场文书
小公司融资,商业计划书的8切记
2019/07/15 职场文书