前端开发开发设计必备常见专用工具涵数小结

日期:2021-03-20 类型:科技新闻 

关键词:图片模板,淘宝作图用什么软件好,在线制作白底图,设计图制作软件,抠图软件

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、标识符串截取应用……弥补


拷贝编码
编码以下:

String.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.getMinutes(), //分
"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 in 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) 回到1个新的涵数给恶性事件便可


拷贝编码
编码以下:

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中1样,回到1个新的涵数


拷贝编码
编码以下:

/**
* 避免数次点一下涵数
*
* fn 进行时启用回调函数
* function fn(event,end) {
* (typeof end === "function") && end(); // 实际操作进行
* }
*/function noRepeateTap(fn) {
var $obj;
return function(event) {
$obj = $(this);
if ($obj.data("loadding") === "true") {
return;
}
$obj.data("loadding", "true").addClass('loadding');
fn.call(this, event, function end() {
$obj.data("loadding", "").removeClass('loadding');
return;
});
}
}

第9个的应用事例


拷贝编码
编码以下:

// 关联恶性事件
$(container).on('click', '.btn-cancel', noRepeateTap(cancel));
// 恶性事件回应涵数
function cancel(event, end) {
event.preventDefault();
// 仿真模拟多线程恳求
setTimeout(function(){
end(); // 必须手动式启用引入的进行涵数,通告进行,涵数全自动加上loadding class 类,用于调剂款式,进行后全自动移除
},5000)
}