前端开发必备常用工具函数小结
网站建设 2023-01-28 20:48www.1681989.com免费网站
1、时间格式化等方法
推荐使用 moment.js 的库文件
2、模板、循环、MAP等方法使用
underscode.js 的方法
3、表单序列化成JSON
复制代码
代码如下:$.fn.serializeJson = function() {
var serializeObj = {};
var array = this.serializeArray();
var str = this.serialize();
$(array).each(function() {
if (serializeObj[this.name]) {
if ($.isArray(serializeObj[this.name])) {
serializeObj[this.name].push(this.value);
} else {
serializeObj[this.name] = [serializeObj[this.name], this.value];
}
} else {
serializeObj[this.name] = this.value;
}
});
return serializeObj;
};
4、字符串截取使用……填补
复制代码
代码如下:Strg.prototype.strcut = function(number) {
var length = this.length;
var tmp = this.substr(0, number);
if (this.length > number) {
tmp += "…";
}
return tmp;
}
5、时间格式为,xxxx 天,xxx分钟前,日期
复制代码
代码如下:Date.prototype.Format = function(fmt, current) {
if (current) {
var diff = current - this.getTime();
if (diff < 5 60 1000) {
return "刚刚";
}
if (diff < 60 60 1000) {
return (Math.floor(diff / (60 1000))) + "分钟前";
}
if (diff < 24 60 60 1000) {
return (Math.floor(diff / (60 60 1000))) + "小时前";
}
if (diff < 30 24 60 60 1000) {
return (Math.floor(diff / (24 60 60 1000))) + "天前";
}
if (diff < 12 30 24 60 60 1000) {
return (Math.floor(diff / (30 24 60 60 1000))) + "月前";
}
if (diff > 12 30 24 60 60 1000) {
return (Math.floor(diff / (12 30 24 60 60 1000))) + "年前";
}
}
var o = {
"Y+": this.getFullYear(), //月份
"M+": this.getMonth() + 1, //月份
"d+": this.getDate(), //日
"h+": this.getHours(), //小时
"m+": this.getMutes(), //分
"s+": this.getSeconds(), //秒
"q+": Math.floor((this.getMonth() + 3) / 3), //季度
"S": this.getMilliseconds() //毫秒
};
if (/(y+)/.test(fmt)) fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
for (var k o)
if (new RegExp("(" + k + ")").test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));
return fmt;
};
6、解析URL
复制代码
代码如下:function parseUrl() {
var arr = location.search.split('?')[1].split('&');
var params = {};
for (var i = 0, l = arr.length; i < l; i++) {
var param = arr[i].split('=');
params[param[0]] = param[1];
}
return params;
}
7、获取get参数
复制代码
代码如下:function getParameterByName(name) {
name = name.replace(/[\[]/, "\\[").replace(/[\]]/, "\\]");
var regex = new RegExp("[\\?&]" + name + "=([^&#])"),
results = regex.exec(location.search);
return results === null ? "" : decodeURIComponent(results[1].replace(/\+/g, " "));
}
8、函数节流,让频繁事件触发更稀疏提高性能,例如及时搜索功能。使用方法为fn 为事件响应函数,delay 为间隔时间,调用 throttle(fn,delay) 返回一个新的函数给事件即可
复制代码
代码如下:function throttle(fn, delay) {
var timer = null;
return function() {
var context = this,
args = arguments;
clearTimeout(timer);
timer = setTimeout(function() {
fn.apply(context, args);
}, delay);
};
}
9、防止表单多次提交,和9中一样,返回一个新的函数
复制代码
代码如下:/
防止多次点击函数
fn 完成时调用回调
function fn(event,end) {
(typeof end === "function") && end(); // 操作完成
}
/function noRepeateTap(fn) {
var $obj;
return function(event) {
$obj = $(this);
if ($obj.data("loaddg") === "true") {
return;
}
$obj.data("loaddg", "true").addClass('loaddg');
fn.call(this, event, function end() {
$obj.data("loaddg", "").removeClass('loaddg');
return;
});
}
}
第9个的使用例子
复制代码
代码如下:// 绑定事件
$(contaer).on('click', '.btn-cancel', noRepeateTap(cancel));
// 事件响应函数
function cancel(event, end) {
event.preventDefault();
// 模拟异步请求
setTimeout(function(){
end(); // 需要手动调用注入的完成函数,通知完成,函数自动添加loaddg class 类,用于调整样式,完成后自动移除
},5000)
}
上一篇:浅谈H标签定义和注意事项
下一篇:分享15个最佳的HTML/CSS设计和开发框架
网站设计
- 静宁会SEO的网站建设公司:全面提升您的网络影
- 提升在线业务的关键:选择最佳的丽水网站建设
- 浙江网站优化发展潜力如何
- 井研专业的网站建设公司:打造您的在线品牌
- 灵山SEO网站建设公司:提升您的在线业务表现
- 蒙城网站建设优化公司:提升您网站表现的理想
- 阳谷企业网站优化:提升线上业务力的关键
- 樟树专业的网站建设公司:打造您在线业务的坚
- 通河百度SEO排名的策略与技巧
- 重庆百度快照排名如何进行精准的客户引流
- 重庆百度快照排名
- 常宁便宜的建站公司:助您轻松打造在线业务
- 巫溪百度网站优化:提升网站曝光率与流量的关
- 湖北整站优化怎么做才能放大客户需求
- 闸北网站建设多少钱?全面解析与预算规划
- 辽宁企业网站优化怎么做电话营销