react频繁使用的js(input防抖请求、节流)

目录

react频繁使用的js(input防抖请求)

input的防抖请求

js 复制代码
import React, { useState, useEffect, useCallback } from "react";
import { Input } from "antd";
import SearchDeptID from "styled-components";
import { debounce } from "lodash";
export default function SearchDept(props) {
  const [keyword, setKeyword] = useState("");

  // input使用防抖
  const keywordDebounce = useCallback(debounce((val)=>{
    console.log('val',val);
  }, 300),[])
  const inputChange = (event) => {
    const value = event.target.value;
    setKeyword(value);
    keywordDebounce(value);
  }

  return (
    <SearchDeptWrap>
      <Input
        placeholder="请输入"
        className="ipt"
        value={keyword}
        onChange={inputChange}
      />
    </SearchDeptWrap>
  );
}
const SearchDeptWrap = SearchDeptID.div`
`;

节流 提交的节流或者点击按钮等节流

节流 code

js 复制代码
import { throttle } from 'lodash';
import React, { useCallback, useState } from 'react';

export default function App(props) {
  const [count, setCount] = useState(0);

  const throttleFunc = useCallback(
    throttle(() => {
      console.log('throttleFunc');
      setCount((prevCount) => prevCount + 1);
    }, 1000),
    []
  );

  const addCount = () => {
    console.log('addCount');
    throttleFunc();
  };

  return (
    <div className='content'>
      count-{count}
      <button onClick={addCount}>addCount</button>
    </div>
  );
}

节流 效果

相关推荐
Zyx200720 小时前
JavaScript 中的 this:作用域陷阱与绑定策略
javascript
唐叔在学习20 小时前
前端响应式设计实践:布局与字体自适应方案
前端·响应式设计
海云前端120 小时前
如果要设计一个开源的Code EditorSDK,你会向开发者暴露哪些API?
前端
2501_9462447820 小时前
Flutter & OpenHarmony OA系统底部导航栏组件开发指南
android·javascript·flutter
Access开发易登软件21 小时前
Access 数据可视化:如何制作箱形图
前端·数据库·vba·access·access开发
Tiramisu202321 小时前
【VUE】删除 node_modules几种高效方法
前端·javascript·vue.js
钰fly21 小时前
Windows Forms开发工具与功能总结表
前端·c#
共享家952721 小时前
测试常用函数(一)
java·前端·javascript
两个人的幸福online21 小时前
给cocos 3.8 消息控制器
开发语言·javascript·ecmascript
林恒smileZAZ21 小时前
vue对接海康摄像头-H5player
前端·javascript·vue.js