【整理分享】11个JS必须学会的实用工具方法

本篇文章给大家整理分享javascript 必须学会的11 个工具方法(避免重复造轮子),希望对大家有所帮助!

【整理分享】11个JS必须学会的实用工具方法

前俩天也是更新了俩篇 JavaScript 的文章,当时由于时间问题,所以就是想到哪里写到哪里,因为对于技术文章只有三五句,几分钟就阅读完,属实无趣,这次趁着周六日有时间好好整理下,尽可量多写一些,下面有具体实现,还有详细注释

计算距离下次生日还有多少天

注意这里借助 moment 实现

    getBirthdayFun(){       // 首先要获取到今年的生日      let birthdayTime = moment().format('YYYY-') + '12-19'      // 通过时间戳  去判断当前的时间戳是否大于今年生日的时间戳       if (moment().unix() >= moment(birthdayTime).unix()) {        // 如果大于的话,那么就在今年的生日上再添加一年,已达到获取下次生日的时间        birthdayTime = moment(birthdayTime).add(1, 'y').format('YYYY-MM-DD')      }      // 这个直接通过计算 (下次生日的时间戳 - 当前日期的时间戳) / (60 * 60 * 24) 最后求出来的就是 XX 天      return parseInt(        (moment(birthdayTime).unix() - moment().unix()) / (60 * 60 * 24)      )    }

登录后复制

回到顶部

    // 这里我把 vue3 的案例拿过来    const bindTop = () => {       // 方法一 这样可以实现,但是效果不太行       window.scrollTo(0, 0)       document.documentElement.scrollTop = 0;              // 方法二 通过计时器去滚动 视觉上会丝滑一些,没有太大的卡顿效果      const timeTop = setInterval(() => {        // 去控制他的滑行距离        document.documentElement.scrollTop = scrollTopH.value -= 50        // 当滑到顶部的时候记得清除计时器(*) 重点        if (scrollTopH.value <= 0) {          clearInterval(timeTop)        }      }, 10)    }

登录后复制

复制文本

    const copyText = (text) => {        // clipboardData 在页面上将需要的东西复制到剪贴板上        const clipboardData = window.clipboardData        if (clipboardData) {          clipboardData.clearData()          clipboardData.setData('Text', text)          return true        } else if (document.execCommand) {  // 注意 document.execCommand 已弃用 但是有些浏览器依旧支持 用的时候记得看兼容情况          // 通过创建 dom 元素,去把要复制的内容拿到           const el = document.createElement('textarea')          el.value = text          el.setAttribute('readonly', '')          el.style.position = 'absolute'          el.style.left = '-9999px'          document.body.appendChild(el)          el.select()          // 拷贝当前内容到剪贴板          document.execCommand('copy')          // 删除 el 节点          document.body.removeChild(el)          return true        }        return false      }      copyText('hello!') // ctrl + v = copyText  | true

登录后复制

防抖/节流

简单介绍

防抖:指定时间内 频繁触发一个事件,以最后一次触发为准节流:指定时间内 频繁触发一个事件,只会触发一次

应用场景有很多比如:防抖是: input搜索,用户在不断输入内容的时候,用防抖来减少请求的次数并且节约请求资源节流:场景普遍就是按钮点击,一秒点击 10 下会发起 10 次请求,节流以后 1 秒点再多次,都只会触发一次

下面我们来实现

    // 防抖    // fn 需要防抖的函数,delay 为定时器时间    function debounce(fn,delay){        let timer =  null  // 用于保存定时器        return function () {             // 如果timer存在 就清除定时器,重新计时            if(timer){                clearTimeout(timeout);            }            //设置定时器,规定时间后执行真实要执行的函数            timeout = setTimeout(() => {               fn.apply(this);            }, delay);        }    }        // 节流    function throttle(fn) {      let timer = null; // 首先设定一个变量,没有执行定时器时,默认为 null      return function () {        if (timer) return; // 当定时器没有执行的时候timer永远是false,后面无需执行        timer = setTimeout(() => {          fn.apply(this, arguments);           // 最后在setTimeout执行完毕后再把标记设置为true(关键)           // 表示可以执行下一次循环了。          timer = null;        }, 1000);      };    }

登录后复制

过滤特殊字符

    function filterCharacter(str){        // 首先设置一个模式        let pattern = new RegExp("[`~!@#$^&*()=:”“'。,、?|{}':;'%,\[\]./?~!@#¥……&*()&;—|{ }【】‘;]")        let resultStr = "";        for (let i = 0; i < str.length; i++) {            // 主要通过 replace ,pattern 规则 去把字符替换成空 最后拼接在 resultStr            resultStr = resultStr + str.substr(i, 1).replace(pattern, '');        }        // 当循环结束的时候返回最后结果 resultStr        return resultStr;    }        // 示例    filterCharacter('gyaskjdhy12316789#$%^&!@#1=123,./[') // 结果:gyaskjdhy123167891123

登录后复制

常用正则判断

    // 校验2-9位文字 不符合为 false  符合为 true    const validateName = (name) => {      const reg = /^[u4e00-u9fa5]{2,9}$/;      return reg.test(name);    };    // 校验手机号    const validatePhoneNum = (mobile) => {      const reg = /^1[3,4,5,6,7,8,9]d{9}$/;      return reg.test(mobile);    };    // 校验6到18位大小写字母数字下划线组成的密码    const validatePassword = (password) => {      const reg = /^[a-zA-Z0-9_]{6,18}$/;      return reg.test(password);    };

登录后复制

初始化数组

    // fill()方法 是 es6新增的一个方法 使用指定的元素填充数组,其实就是用默认内容初始化数组    const arrList = Array(6).fill()    console.log(arrList)  // 此处打印的是 ['','','','','','']

登录后复制

将 RGB 转换为十六进制

    function getColorFun(r,g,b) {       return '#' + ((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1)    }        getColorFun(178,232,55) // 这里输出的是 #b2e837

登录后复制

检测是否是一个函数

    // 检测是否是一个函数  其实写法以后直接 isFunction 就好了,避免重复写判断    const isFunction = (obj) => {        return typeof obj === "function" && typeof obj.nodeType !== "number" && typeof obj.item !== "function";    };

登录后复制

检测是否为一个安全数组

  // 检测是否为一个安全数组,若不是返回空数组  这里借助isArray 方法  const safeArray = (array) => {    return Array.isArray(array) ? array : []  }

登录后复制

检测对象是否为一个安全对象

    // 首先要去判断 当前对象是否为有效对象     const isVaildObject = (obj) => {        return typeof obj === 'object' && !Array.isArray(obj) && Object.keys(obj).length    }    // 这里直接用上面的函数 如果有效就返回本身,无效就返回空对象    const safeObject = obj => isVaildObject(obj) ? obj : {}

登录后复制

最后

上面案例有些代码都是在我单独的 v3 项目里面,如果有需要可以关注我,然后找我要资料,或者需要面试题什么的也都可以找我,都有哈,上面文章如果有不清楚的地方,麻烦指出,希望对大家都能有一定程度的帮助,谢谢支持~

(学习视频分享:web前端开发、编程基础视频)

以上就是【整理分享】11个JS必须学会的实用工具方法的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2698140.html

(0)
上一篇 2025年3月7日 18:47:38
下一篇 2025年3月7日 18:47:51

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 详解js在html中的加载执行顺序

    js在html中的加载执行顺序 1.加载顺序:引入标记的出现顺序, 页面上的js代码是js的一部分,所以Javascript在页面装载时执行的顺序就是其引入标记的出现顺序, 标记里面的或者通过src引入的外部JS,都是按照其语句出现的顺序执…

    编程技术 2025年4月4日
    100
  • HTML和JS实现简单的计算器

    HTML和JS实现计算器功能的也是很容易的,本文主要和大家分享HTML和JS实现简单的计算器,希望能帮助到大家。 下面是代码:    nbsp;html>无标题文档 var result=””; function jisuan(num…

    编程技术 2025年4月4日
    100
  • 实现在HTML页面加载完毕后运行js方法

    本文主要和大家分享实现在HTML页面加载完毕后运行js方法,主要以代码的方法和大家分享,希望能帮助到大家。 Js方法: window.onload=function (){ var userName=”xiaoming”; alert(us…

    编程技术 2025年4月4日
    100
  • JavaScript实现获取远程的html到当前页面中

    今天做个项目,需要在当前的html页面中引用一个远程的html页面,百度了一下,发现一个非常好用的代码,这里分享给大家,有相同需求的小伙伴可以来看看 html代码 登录后复制 立即学习“Java免费学习笔记(深入)”; javascript…

    编程技术 2025年4月4日
    200
  • JavaScript模块优化

    给大家分享一下如何才能开发出更好的javascript模块和功能,有兴趣的朋友参考学习下吧。 不少人都曾经在 npm 上发布过自己开发的 JavaScript 模块,而在使用一些模块的过程中,我经常产生“这个模块很有用,但如果能 xxx 就…

    编程技术 2025年4月4日
    100
  • 适用于JavaScript开发人员的10个必备VSCode扩展

    如今,visual studio code无疑是最流行的轻量级代码编辑器。它确实从其他代码编辑器那借鉴了很多,最主要是从sublime和atom那里。然而它的成功关键是源于能提供更好的性能和稳定的表现。 另外,它还提供了如代码智能提示等开发…

    2025年4月2日 编程技术
    200
  • 提高 JavaScript 开发效率的高级 VSCode 扩展!

    如今,visual studio code无疑是最流行的轻量级代码编辑器。vs code的强大无疑来自于它的插件市场。多亏了开源社区,vs code现在几乎对所有的编程语言、框架和开发技术都有支持。 提供这种支持的方式是多样的,主要包括了为…

    2025年4月2日 编程技术
    200
  • 如何利用Vue实现拖拽穿梭框功能?四种方式介绍

    如何实现拖拽穿梭框功能?下面本篇文章给大家介绍一下vue实现拖拽穿梭框功能四种方式,希望对大家有所帮助。 【相关推荐:vue】 一、使用原生js实现拖拽 vue Lazyload .drag { background-color: skyb…

    2025年4月1日
    100
  • 聊聊MVVM模型在Vue中怎么应用

    理解MVVM模型 我们知道每一个 Vue 应用都是从创建一个新的实例开始的,根据 Vue2 的官方文档我们可以得知 Vue 的设计是得到了 MVVM 模型 的启发,所以就有了在我们创建 Vue 实例时,文档中经常使用vm这个变量名来表示 V…

    2025年4月1日 编程技术
    200
  • 浅析Vue3动态组件怎么进行异常处理

    vue3动态组件怎么进行异常处理?下面本篇文章带大家聊聊vue3 动态组件异常处理的方法,希望对大家有所帮助! 【相关推荐:vuejs视频教程】 动态组件有两种常用场景: 一是动态路由: 立即学习“前端免费学习笔记(深入)”; // 动态路…

    2025年4月1日
    100

发表回复

登录后才能评论