前端解决按钮重复提交数据问题(节流和防抖)
文章目录
- 一、问题
- 二、 解决方案(通过节流防抖解决)
- 总结
一、问题
当我们在页面进行点点点的操作时,很可能遇到点击两次的行为,这时候提交或保存按钮也没有进行校验,很可能保存两份数据,因此,作为开发人员,对需要保存类似的按钮进行校验很有必要。
二、 解决方案(通过节流防抖解决)
场景:解决按钮多次点击重复提交数据问题
防抖方法(debounce.js)
let timeout = null
/**
* 防抖原理:一定时间内,只有最后一次操作,再过wait毫秒后才执行函数
*
* @param {Function} func 要执行的回调函数
* @param {Number} wait 延时的时间
* @param {Boolean} immediate 是否立即执行
* @return null
*/
function debounce(func, wait = 500, immediate = false) {
// 清除定时器
if (timeout !== null) clearTimeout(timeout)
// 立即执行,此类情况一般用不到
if (immediate) {
const callNow = !timeout
timeout = setTimeout(() => {
timeout = null
}, wait)
if (callNow) typeof func === 'function' && func()
} else {
// 设置定时器,当最后一次操作后,timeout不会再被清除,所以在延时wait毫秒后执行func回调方法
timeout = setTimeout(() => {
typeof func === 'function' && func()
}, wait)
}
}
export default debounce
节流方法(throttle.js)
let timer; let
flag
/**
* 节流原理:在一定时间内,只能触发一次
*
* @param {Function} func 要执行的回调函数
* @param {Number} wait 延时的时间
* @param {Boolean} immediate 是否立即执行
* @return null
*/
function throttle(func, wait = 500, immediate = true) {
if (immediate) {
if (!flag) {
flag = true
// 如果是立即执行,则在wait毫秒内开始时执行
typeof func === 'function' && func()
timer = setTimeout(() => {
flag = false
}, wait)
}
} else if (!flag) {
flag = true
// 如果是非立即执行,则在wait毫秒内的结束处执行
timer = setTimeout(() => {
flag = false
typeof func === 'function' && func()
}, wait)
}
}
export default throttle
在mian.js进行挂载使
// 防抖方法
import debounce from './plugins/debounce'
// 节流方法
import throttle from './plugins/throttle'
const $u = {
debounce,
throttle
}
// 挂载节流防抖到原型
Vue.prototype.$u = $u
组件中使用
<el-button
icon="iconfont icon-save-line"
type="primary"
@click="$u.throttle(() => getAllData(), 1000)"
>保存
</el-button>
<!-- getAllData 按钮触发方法 1000时间 -->
总结
如果这篇【文章】有帮助到你💖,希望可以给我点个赞👍,创作不易,如果有对前端端或者对python感兴趣的朋友,请多多关注💖💖💖,咱们一起探讨和努力!!!
👨🔧 个人主页 : 前端初见
前端初见: 你可以根据需要引入,这篇这是我写demo用到的,一般选择一个相对稳定的使用即可 ,v1.4以及以前的版本无序申请秘钥(ak),自v1.5版本开始需要先申请秘钥(ak),才可以使用。另外百度地图API的1.1和2.0两个版本的区别,推荐使用显示效果更好的2.0版本,并提供了注册、申请密匙的步骤。针对2.0版本,展示了代码示例,包括地图初始化、标注图标、地图加载问题的解决方案,以及如何处理地图标注乱码问题。还提供了一些完整示例代码供参考
baikou999: api里有个版本v=1.0或者v=其他的有什么区别吗
咸鱼翻身: https://www.npmjs.com/package/@cennavi-fe/minemap
前端初见: 公司会退供对应的key
Bonny雨曦: 公司用的话是不是就得付费