分享 8 个超级实用的前端代码片段,总要用得上的!

yumo6667个月前 (04-23)技术文章32

1、检测点击元素外部

比如你想要点击弹窗外部去关闭弹窗,或者 Vue 的自定义指令 clickoutside,都是利用了下面这个代码片段

2、一次性事件监听

相信大家都用过 addEventListener吧?你监听后想要解除需要用到 removeEventListener,但是如果你只是想要一次性监听的话,可以传入第三个参数

3、手动解除事件监听

还是 addEventListener,如果你不想使用 removeEventListener 去解除监听的话,你也可以使用 AbortController + signal 去进行手动解除监听

4、控制并发数

现在前端中使用异步操作已经是常态,更别说异步请求了,而当异步请求并发量比较高的时候,为了节约网络资源提高用户体验,我们需要控制并发数

limitFn 的具体实现我放在下面了

const limitFn = (limit) => {
  const queue = [];
  let activeCount = 0;

  const next = () => {
    activeCount--;

    if (queue.length > 0) {
      queue.shift()();
    }
  };

  const run = async (fn, resolve, ...args) => {
    activeCount++;

    const result = (async () => fn(...args))();


    try {
      const res = await result;
      resolve(res);
    } catch { }

    next();
  };

  const enqueue = (fn, resolve, ...args) => {
    queue.push(run.bind(null, fn, resolve, ...args));

    if (activeCount < limit && queue.length > 0) {
      queue.shift()();
    }
  };

  const generator = (fn, ...args) =>
    new Promise((resolve) => {
      enqueue(fn, resolve, ...args);
    });

  return generator;
};

5、生成唯一ID

也就是生成一个唯一的 uuid,其实现在很多库都可以做,比如 lodash,当然你也可以自己写一个

const uuid = (a) =>
  a
    ? (a ^ ((Math.random() * 16) >> (a / 4))).toString(16)
    : ([1e7] + -1e3 + -4e3 + -8e3 + -1e11).replace(/[018]/g, uuid)

6、格式化时分秒

如果你想要把时间格式化成 HH:mm:ss 这样的话

const formatSeconds = (s) =>
  [parseInt(s / 60 / 60), parseInt((s / 60) % 60), parseInt(s % 60)]
    .join(':')
    .replace(/\b(\d)\b/g, '0$1')

7、提取 URL 的参数

可以将 URL 上的参数提取出来,变成一个对象

const getUrlParams = (query) =>
  Array.from(new URLSearchParams(query)).reduce(
    (p, [k, v]) =>
      Object.assign({}, p, { [k]: p[k] ? (Array.isArray(p[k]) ? p[k] : [p[k]]).concat(v) : v }),
    {}
  )

8、打开弹窗时禁止页面滚动

当我们打开弹窗时,我们不希望整个页面还能滚动,那么可以在打开弹窗时去设置页面的滚动样式

相关文章

WINCC如何制作滚动播放的文字

首先,我们先看一下文字播放的效果。如视频所示,文字呈跑马灯的形式进来左右来回滚动,那么在wincc中,如果制作这样的效果呢?带着赖工,学会它!第一步:首先在页面合适的位置,新建一个,静态文本,属性见图...

selenium:操作滚动条的方法(8)

selenium支持几种操作滚动条的方法,主要介绍如下:使用ActionChains 类模拟鼠标滚轮操作使用函数ActionChains.send_keys发送按键Keys.PAGE_DOWN往下滑动...

Excel制作字幕滚动窗体

要制作字幕上下滚动的窗体,可以结合Windows API函数,并修改标签位置来滚动字幕。思路字幕,可以通过设置Label标签的标题来实现。字幕滚动,可以在循环中动态修改Label位置。知识点本节需要用...

告别繁琐代码?Maxun:你的无代码网页数据抓取新选择

告别繁琐代码?Maxun:你的无代码网页数据抓取新选择还在为网页数据抓取而头疼吗?还在苦苦学习复杂的编程语言吗?别担心,开源项目 Maxun 来了!它就像一位魔法师,让你无需编写任何代码,就能轻松驾驭...

如何在网页上高效渲染 1000 万张小图片的?

最近,看到一个名为 10MPage.com 的网站,目标是记录 2025 年互联网的时代印记。每个用户都可以上传一张 64x64 像素的小图片,形成一个庞大的互联网影像档案。正如名字所暗示的,这个页面...

CSS Houdini 是个啥?让你的网页“魔法上身”!

有一天,设计师又来了:“这个按钮的背景加个动态星云效果,颜色随着页面滚动变化,行吗?”还有产品经理:“咱的列表能不能整得像Pinterest那样,排列得艺术点?”你抬头看着他们,又低头看着CSS文档,...