一线大厂常用的六大vue自定义指令合集之节流v-throttle

前言

截至目前,一线大厂常用的6大vue自定义指令中,我们已经学习实现了3个了,而其中上一篇
一线大厂常用的六大vue自定义指令合集之防抖v-debounce中的自定义防抖指令与我们今天要学习的节流自定义指令除了函数不一样,其它的基本上是一模一样。下面让我们一起来揭开它的面纱吧!
关于javascript中是如何实现节流,这里不再过多赘述,感兴趣的小伙伴可以查看这篇web前端高级JavaScript - 函数的防抖和节流文章了解更多。本篇文章主要介绍如何实现一个节流的自定义指令,下面我们就来分析一下大体实现思路。

思路分析

  • 节流函数一般会接收2个参数:一个是节流函数中要执行的具体函数func,另一个则是节流等待的时间wait。
    同样需要传递多个参数给指令函数时,我们可以组装一个对象一起传递
  • wait参数仍然可以以冒号的形式进行传递
  • 对于指令函数体内接收到的参数进行判断处理:如果是函数直接传给节流函数,如果是对象则需对对象进行解析拆分。
  • 另外还是为了让我们的自定义指令更灵活更通用,我们仍然需要在指令函数中再额外接收一个type和一个params参数,分别用来标识是什么类型的节流和节流函数所需的参数
    • 最后就是除了函数以外的其它参数均需设置默认值。
  • 最后让我们把节流的完整代码来实现一下

v-th节流rottle自定义指令代码

function throttle(func, wait){
   
	let timer = null,
		previous = 0;
	return function anonmouse(...params){
   
		let now = new Date(),
			remaining = wait - (now - previous
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue定义指令可以用来扩展Vue组件的行为,为`v-bind`指令添加额外的功能。在`el-table-column`中使用自定义指令,通常是为了动态地设置列的属性,比如根据某些条件改变列宽、隐藏或显示等。下面是一个简单的例子,展示如何使用自定义指令设置`el-table-column`的属性: ```html <template> <el-table-column v-custom-column-width="myColumnWidth" :prop="columnProp" :label="columnLabel" /> </template> <script> export default { directives: { customColumnWidth: { // 指令定义 bind(el, binding, vnode) { // 当指令绑定时执行,binding.value是传入的参数 el.columnWidth = binding.value; }, update(value, oldVnode) { // 当指令值更新时执行 vnode.context.$emit('update:customColumnWidth', value); }, }, }, data() { return { myColumnWidth: '200px', // 初始列宽 columnProp: 'property', // 列的prop属性 columnLabel: 'Column Label' // 列的标签 }; }, }; </script> ``` 在这个例子中,我们定义了一个名为`customColumnWidth`的自定义指令,`bind`方法在指令被绑定到元素时执行,将`myColumnWidth`的值设置为列的宽度。`update`方法在指令值发生变化时,触发`update:customColumnWidth`事件,从而更新列的宽度。 使用时,可以通过`v-custom-column-width`绑定数据属性,例如: ```html <template> <el-table-column v-custom-column-width="computedWidth" :prop="columnProp" :label="columnLabel" /> </template> <script> // 在计算属性中动态设置width computed: { computedWidth() { return this.someCondition ? '200px' : '150px'; // 根据someCondition动态决定宽度 } } </script> ``` 相关问题: 1. Vue定义指令的基本用法是什么? 2. 如何在Vue定义和使用自定义事件? 3. `v-once`指令有什么作用?

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值