前端開發(fā)的常用工具函數(shù)有哪些

這篇文章主要講解了“前端開發(fā)的常用工具函數(shù)有哪些”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“前端開發(fā)的常用工具函數(shù)有哪些”吧!

富蘊(yùn)ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)公司的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:13518219792(備注:SSL證書合作)期待與您的合作!

1、時間格式化等方法

推薦使用 moment.js 的庫文件

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、時間格式為,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參數(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ā)更稀疏提高性能,例如及時搜索功能。使用方法為fn 為事件響應(yīng)函數(shù),delay 為間隔時間,調(diào)用 throttle(fn,delay) 返回一個新的函數(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中一樣,返回一個新的函數(shù)

代碼如下:


/**
* 防止多次點擊函數(shù)
*
* fn 完成時調(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個的使用例子

代碼如下:


// 綁定事件
$(container).on('click', '.btn-cancel', noRepeateTap(cancel));
 // 事件響應(yīng)函數(shù)
 function cancel(event, end) {
   event.preventDefault();
      // 模擬異步請求
       setTimeout(function(){
     end(); // 需要手動調(diào)用注入的完成函數(shù),通知完成,函數(shù)自動添加loadding class 類,用于調(diào)整樣式,完成后自動移除
   },5000)
 }

感謝各位的閱讀,以上就是“前端開發(fā)的常用工具函數(shù)有哪些”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對前端開發(fā)的常用工具函數(shù)有哪些這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

標(biāo)題名稱:前端開發(fā)的常用工具函數(shù)有哪些
網(wǎng)站網(wǎng)址:http://muchs.cn/article34/gedipe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站虛擬主機(jī)、面包屑導(dǎo)航、ChatGPT、網(wǎng)站排名、網(wǎng)站導(dǎo)航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化