您好,登錄后才能下訂單哦!
這篇文章主要講解了“前端開(kāi)發(fā)的常用工具函數(shù)有哪些”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“前端開(kāi)發(fā)的常用工具函數(shù)有哪些”吧!
1、時(shí)間格式化等方法
推薦使用 moment.js 的庫(kù)文件
2、模板、循環(huán)、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、字符串截取使用……填補(bǔ)
代碼如下:
String.prototype.strcut = function(number) {
var length = this.length;
var tmp = this.substr(0, number);
if (this.length > number) {
tmp += "…";
}
return tmp;
}
5、時(shí)間格式為,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))) + "小時(shí)前";
}
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(), //小時(shí)
"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參數(shù)
代碼如下:
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、函數(shù)節(jié)流,讓頻繁事件觸發(fā)更稀疏提高性能,例如及時(shí)搜索功能。使用方法為fn 為事件響應(yīng)函數(shù),delay 為間隔時(shí)間,調(diào)用 throttle(fn,delay) 返回一個(gè)新的函數(shù)給事件即可
代碼如下:
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中一樣,返回一個(gè)新的函數(shù)
代碼如下:
/**
* 防止多次點(diǎn)擊函數(shù)
*
* fn 完成時(shí)調(diào)用回調(diào)
* 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個(gè)的使用例子
代碼如下:
// 綁定事件
$(container).on('click', '.btn-cancel', noRepeateTap(cancel));
// 事件響應(yīng)函數(shù)
function cancel(event, end) {
event.preventDefault();
// 模擬異步請(qǐng)求
setTimeout(function(){
end(); // 需要手動(dòng)調(diào)用注入的完成函數(shù),通知完成,函數(shù)自動(dòng)添加loadding class 類(lèi),用于調(diào)整樣式,完成后自動(dòng)移除
},5000)
}
感謝各位的閱讀,以上就是“前端開(kāi)發(fā)的常用工具函數(shù)有哪些”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)前端開(kāi)發(fā)的常用工具函數(shù)有哪些這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。