$ mkdir office-supplies
$ cd office-supplies
$ slc loopback
$ slc loopback:model product
$ slc run
//server.js
app.set('view engine', 'jade'); //添加jade
app.set('views', __dirname + '/views'); //添加目录server/views,注意这里是在server中
"files": {
"loopback#static": {
"params": "$!../client"
}
},
/routers/index.js
module.exports = function(app) {
var router = app.loopback.Router();
router.get('/', function(req, res, next) {
res.render('index', {user: null});
});
return router
};
var index = require('../routers/index')(server);
server.use('/', index);
//server.js; 安装coffee-script之后
var coffeeScript = require('coffee-script');
coffeeScript.register();
//或
require('coffee-script');
Gulpfile.js
文件//Gulpfile.js
var gulp = require('gulp');
require('gulp-load-params')(gulp); //安装;之后使用`gulp.loadTasks`
gulp.loadTasks(__dirname); //在文件同级建立tasks文件夹
gulp.task('default',['watch']); //1.执行watch
//tasks/watch.js
module.exports = function(gulp){
var livereload = require('gulp-livereload'); //安装,同时下载chrome相应插件
gulp.task('reload', function(){
gulp.src(['./server/views/**/*.jade'])
.pipe(livereload());
}); //4
gulp.task('watch:frontend', function(){
livereload.listen();
gulp.watch([
'./client/javascripts/**/*.js',
'./client/stylesheets//**/*.css',
'./server/views/**/*.jade'
], ['reload']); //3.创建并监听,这三个文件夹改变的时候执行reload
});
gulp.task('watch:frontend:coffee', function(){
gulp.watch('./coffee/**/*.coffee', ['coffee:client']) //创建coffee文件夹并添加coffeescript文件
}); //3.监听.coffee,改变的时候执行coffee:client; 这里写client区分服务器端的coffee
gulp.task('watch:frontend:less', function(){
gulp.watch('./less/**/*.less', ['less']) //创建less文件夹并添加less文件
}) //3.监听.less,改变的时候执行less;
gulp.task('watch', [
'watch:frontend:coffee',
'watch:frontend:less',
'watch:frontend'
]); //2.执行这三个
}
//tasks/less.js
module.exports = function(gulp){
var less = require('gulp-less');
var minify = require('gulp-minify-css');
gulp.task('less', function(){
gulp.src('./less/**/*.less')
.pipe(less())
.pipe(minify())
.pipe(gulp.dest('./client/stylesheets/'))
}); 4.编译,压缩并输出less文件
}
//tasks/coffee.js
module.exports = function(gulp){
var coffee = require('gulp-coffee');
var coffeeLint = require('gulp-coffeelint');
gulp.task('coffee:client', function(){
gulp.src('./coffee/**/*.coffee')
.pipe(coffeeLint())
.pipe(coffee())
.pipe(gulp.dest('./client/javascripts/'));
}); 4.编译并输出js文件
}
package.json
文件; 也可以利用gulp-nodemon
将自动启动设置在gulpfile.js
中;//在package.json的scripts中添加
"start": "nodemon -e 'js, coffee, json' ./server/server.js" //分别重新启动表示监听的文件夹后缀名和重新启动执行的文件名
//运行 npm start
boot(app, [options], [callback])
: Initialize an application from an options object or a set of JSON and JavaScript files.如果options是string类型的话,将其设置为root路径;然后
如果是对象,就会相应查找models
,dataSources
等属性来配置,具体查看boot
querystring
包是nodejs自带的;var qs = require('querystring');
var user = {name: "jinks", age: 23}
user = qs.stringfy(user);
//name=jinks&age=23
npm install --save-dev