nodejs实用工具
- 基于moment的工具moment-utils,您也可以继承此工具类并扩展出新的方法,使用方法如下:
代码
先解压文件到你项目下的node_modules文件夹下,然后引入即可。
/**
* 这里采用ES6以上的语法,要使用es5语法,可以使用babel-node转换
* 1、引入moment-utils
* 2、构造对象时,可以接受两个参数date[日期],format[格式化字符串,和moment一样,比如YYYY-MM-DD HH:mm:ss]
* 3、使用工具
*/
//es6以上
const MomentUtils = require('moment-utils');
const moment = new MomentUtils();
exports.dateFormatenl = (date)=> moment.dateFormatEnl(date) //YYYY-MM-DD HH:mm:ss
exports.dateFormatens = (date)=> moment.dateFormatEns(date) //YYYY-MM-DD
exports.dateFormatch = (date)=> moment.dateFormatCh(date)//YYYY年MM月DD日
exports.dateFormatchhh = (date)=> moment.dateFormatChhh(date)//YYYY年MM月DD日HH点
exports.dateNow = () => moment.dateNowEns() //YYYY-MM-DD
exports.dateNowDetail = () => moment.dateNowEnl() //YYYY-MM-DD HH:mm:ss
//es5
var MomentUtils = require('moment-utils');
var moment = new MomentUtils();
exports.dateFormatenl = function(date){
return moment.dateFormatEnl(date);
}
exports.dateFormatens = function(date){
return moment.dateFormatEns(date);
}
exports.dateFormatch = function(date){
return moment.dateFormatCh(date);
}
exports.dateFormatchhh = function(date){
return moment.dateFormatChhh(date);
}
exports.dateNow = function() {
return moment.dateNowEns();
}
exports.dateNowDetail = function() {
return moment.dateNowEnl();
}
- 基于sequelize的工具sequelize-utils(Sequelize工具v1.1,请下载v1.1版本,修复了部分mysql类型不支持的问题),您也可以继承此工具类并扩展出新的方法,使用方法如下:
代码
先解压文件到你项目下的node_modules文件夹下,然后引入即可。
sequelize.js文件内容如下
//Sequelize工具文件引入
const Sequelize = require('sequelize-utils');
//数据库配置文件引入
const settings = require('../config');
//自定义生成模型的路径以及require引入模型路径(即,是同一个路径)
const filePath = settings.root+'/models/sequelize_models';
//时区定义
process.env.TZ = 'Asia/Shanghai';
const sequelize = new Sequelize(settings.mysql.database, settings.mysql.user, settings.mysql.password,
{host : settings.mysql.host, port : settings.mysql.port, dialect : 'mysql',operatorsAliases: false,
timezone: process.env.TZ,
define: {
// 字段以下划线(_)来分割(默认是驼峰命名风格)
underscored: true
}
},{filePath:filePath,requirePath:filePath,sequelize_table_value:settings.mysql.sequelize_table_value},(modelkey,seqmodel,sequelize,Sequelise)=>{
sequelize[modelkey]=seqmodel(sequelize,Sequelise);
});
module.exports = sequelize;
完成以上操作后,可自动把数据库的表生成对应的模型,此时,就可以引用模型进行数据库增删改查。比如,
代码
testSequelizeUtils.js文件内容如下
//引入工具,可调用原生Sequelize的属性和方法,注意是大写字母开头
const Sequelize = require('sequelize-utils');
//文件为刚刚定义的sequelize.js文件,注意是小写字母开头
const sequelize = require('../sequelize');
//使用自动生成的model模型进行增删改查
//sql是sql语句:比如select * from user where id=$key
//bind是绑定key值到$key上
//执行sql语句方法
sequelize.query(sql,{bind:{key:'1'}}).then((ret)=>{
//TO DO...
},(err)=>{
//TO DO...
});
//执行增加方法
sequelize.UserModel.create(user).then((ret)=>{
//TO DO...
},(err)=>{
//TO DO...
});
//执行删除方法
sequelize.UserModel.destroy({where:{id:1}).then((ret)=>{
//TO DO...
},(err)=>{
//TO DO...
});
//执行修改方法
sequelize.UserModel.update({userName:'tom'},{where:{id:1}).then((ret)=>{
//TO DO...
},(err)=>{
//TO DO...
});
//执行查询方法
//findAll
//findOne
//....
sequelize.UserModel.findAll({where:{id:1}).then((ret)=>{
//TO DO...
},(err)=>{
//TO DO...
});
请特别注意: 数据库表名的要求是:前缀+’_’+名称1+’_’+名称2…,比如:yh_user表名对应的模型是UserModel,yh_user_same表名对应的模型是UserSameModel,使用的时候直接是类似sequelize.UserModel.findAll()…这种方式。另外,自定义生成模型的路径必须配置准确无误。
结尾
以上就是两个工具的使用方法,如有不慎,敬请谅解!更新于2018-10-12 09:46:23!如需了解更多,请仔细阅读源码和相关说明。
参考
[1]: http://momentjs.cn/