文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

前端开发的常用工具函数有哪些

2023-06-08 02:40

关注

这篇文章主要讲解了“前端开发的常用工具函数有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“前端开发的常用工具函数有哪些”吧!

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) 返回一个新的函数给事件即可

代码如下:


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中一样,返回一个新的函数

代码如下:


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)
 }

感谢各位的阅读,以上就是“前端开发的常用工具函数有哪些”的内容了,经过本文的学习后,相信大家对前端开发的常用工具函数有哪些这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯