nodejs中两款二次封装的实用工具(基于moment和sequelize的工具)

nodejs实用工具

  1. 基于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();
}
  1. 基于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/

[2]: https://blog.csdn.net/zjw0742/article/details/76861013

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值