当前位置: 首页 > wzjs >正文

长沙网站建设建求购买链接

长沙网站建设建,求购买链接,专做苹果二手手机的网站,辽源网站制作需要实现防抖应用场景&#xff1a; 点击【查询】按钮&#xff0c;发送网络请求&#xff0c;等待并接收响应数据 原来点击【查询】的代码&#xff1a; <script setup lang"ts" name"ReagentTransactionsDrawer"> ...... // 查询&#xff0c;没有防…

需要实现防抖应用场景:

点击【查询】按钮,发送网络请求,等待并接收响应数据

原来点击【查询】的代码:

<script setup lang="ts" name="ReagentTransactionsDrawer">
......
// 查询,没有防抖,可以重复点击
const onQueryClick = async () => {// 检查if (queryObj.value.transactionTime.length === 0 &&!queryObj.value.transactionType &&!queryObj.value.materialName) {ElMessage.warning("请输入查询条件!");return;}transactionsList.value = [];let result = await branchWarehouseTransactionsQueryForReagentService(queryObj.value);transactionsList.value = result.data;
};
......
</script><template>
......<el-button class="btn-same-width" type="primary" plain @click="onQueryClick">查询</el-button>
......
</template>

一、使用自定义的防止重复点击组合式函数 hook 

1、编写防止重复点击组合式函数 hook,usePreventReClick.ts

2、导入防止重复点击组合式函数 hook

3、使用 preventReClick 防止重复点击

<script setup lang="ts" name="ReagentTransactionsDrawer">
......
import { usePreventReClick } from "@/hooks/usePreventReClick";
const { preventReClick } = usePreventReClick();// 查询,加装 preventReClick 防抖器,防止重复点击
const onQueryClick = async () => {preventReClick(async () => { // 改动1:增加防抖代码// 检查if (queryObj.value.transactionTime.length === 0 &&!queryObj.value.transactionType &&!queryObj.value.materialName) {ElMessage.warning("请输入查询条件!");return;}transactionsList.value = [];let result = await branchWarehouseTransactionsQueryForReagentService(queryObj.value);transactionsList.value = result.data;}); // 改动2:增加防抖代码
};
......
</script><template>
......<el-button class="btn-same-width" type="primary" plain @click="onQueryClick">查询</el-button>
......
</template>

 防止重复点击组合式函数 hook,usePreventReClick.ts

import { ref } from "vue";type AsyncFunction = () => Promise<any>;/*** 防止重复点击 hook* @returns*/
export function usePreventReClick() {const isClicking = ref(false);const preventReClick = async (fn: AsyncFunction) => {if (isClicking.value) {return;}isClicking.value = true;try {await fn();} finally {isClicking.value = false;}};return {isClicking,preventReClick};
}

 二、使用lodash-es的debounce

1、安装 lodash-es 工具库

2、按需使用导入debounce

3、使用 debounce 防止重复点击

<script setup lang="ts" name="ReagentTransactionsDrawer">
......
import { debounce } from "lodash-es";// 查询,加装 debounce 防抖器,防抖处理(leading: true,立即执行、maxWait: 1000,1秒内至少执行一次)
const onQueryClick = debounce( // 改动1:const onQueryClick = async () => { 改为 const onQueryClick = debounce(async () => {// 检查if (queryObj.value.transactionTime.length === 0 &&!queryObj.value.transactionType &&!queryObj.value.materialName) {ElMessage.warning("请输入查询条件!");return;}transactionsList.value = [];let result = await branchWarehouseTransactionsQueryForReagentService(queryObj.value);transactionsList.value = result.data;}, // 改动2:} 改为 },1000, // 改动3:增加防抖代码{ leading: true, trailing: true, maxWait: 1000 } // 改动4:增加防抖代码
); // 改动5:增加防抖代码
......
</script><template>
......<el-button class="btn-same-width" type="primary" plain @click="onQueryClick">查询</el-button>
......
</template>

三、使用自定义防抖组件 

1、编写防止重复点击按钮组件(防抖按钮组件),BasePreventReClickButton.vue

2、导入防抖组件

3、在模板中使用组件

<script setup lang="ts" name="ReagentTransactionsDrawer">
......
import BasePreventReClickButton from "@/components/base/BasePreventReClickButton.vue";// 查询,使用 BasePreventReClickButton 防抖组件,防止重复点击
const onQueryClick = async () => {// 检查if (queryObj.value.transactionTime.length === 0 &&!queryObj.value.transactionType &&!queryObj.value.materialName) {ElMessage.warning("请输入查询条件!");return;}transactionsList.value = [];let result = await branchWarehouseTransactionsQueryForReagentService(queryObj.value);transactionsList.value = result.data;
};
......
</script><template>
......<BasePreventReClickButton class="btn-same-width" type="primary" plain @click="onQueryClick">查询</BasePreventReClickButton> <!-- 改动1:改用防抖组件 BasePreventReClickButton -->
......
</template>

防止重复点击按钮组件(防抖按钮组件),BasePreventReClickButton.vue

/** * 防止重复点击按钮组件(防抖按钮组件) */
<script setup lang="ts" name="BasePreventReClickButton">
import { ref } from "vue";const props = withDefaults(defineProps<{onClick: () => Promise<void> | void;delay?: number;}>(),{delay: 0}
);// 加载标识
const loading = ref(false);// 点击事件
const handleClick = async (): Promise<void> => {if (loading.value) return;loading.value = true;try {await props.onClick();} finally {let delay = props.delay;if (delay < 0) delay = 0;setTimeout(() => {loading.value = false;}, delay);}
};
</script><template><!-- v-bind="$attrs" 绑定父组件传递的所有属性 --><!-- 设置当前组件的个性属性,可以覆盖父组件属性 :loading="loading" :disabled="loading" @click="handleClick" --><el-button v-bind="$attrs" :loading="loading" :disabled="loading" @click="handleClick"><!-- 插槽 --><slot></slot></el-button>
</template><style scoped lang="scss"></style>
http://www.dtcms.com/wzjs/463505.html

相关文章:

  • 简易做网站百度账号人工申诉
  • 怎么给网站做spm香飘飘奶茶软文
  • 商业网站模板下载杭州上城区抖音seo有多好
  • 百度 网站改版了百度权重5的网站能卖多少钱
  • 茶叶网站flash模板今日国际新闻大事
  • 成都思乐网站建设站长工具综合查询2020
  • 住房和城乡建设部执法网站宁波seo网站服务
  • 济南做兼职网站怎样在百度上发帖子
  • 徐州做网站需要多少钱百度电话怎么转人工客服
  • 棋牌软件开发源代码seo网站排名推广
  • 书籍类wordpress主题排名优化关键词
  • 税务网站建设管理指导思想关键词推广怎么做
  • 湛江宇锋网站建设google官网登录
  • 网站建设的领军 18年网站建设哪家培训机构学校好
  • 网络推广网站排名国外引流推广平台
  • 网站设计怎么做ppt答辩seo外链平台
  • 响应式机械类网站西安网站建设哪家好
  • 今天新闻摘抄十条seo排名优化表格工具
  • 做网站的伪原创怎么弄产品推广方式及推广计划
  • 成都 网站建设旅游网站的网页设计
  • 网站功能架构图怎么做名风seo软件
  • 北京市住房和城乡建设委网站百度一下百度主页度
  • 山西做网站的企业上海快速排名优化
  • 怎么百度上搜到自己的网站安卓手机优化神器
  • 做网站按钮淘宝seo关键词的获取方法有哪些
  • 网站做淘宝客还行吗游戏推广话术
  • 上海网站建设yes404bt磁力在线种子搜索神器下载
  • 网站建设关键字优化舆情监测系统
  • 网站服务器租赁合同网站关键词优化系统
  • 北京手机网站网站排名优化首页