JS劫持其他函数,选择执不执行或其他操作

最近使用Vue业务开发上使用的是低代码框架。 对话框表格等通过数据驱动组件实现功能, 框架表格部分适配框架搞得一塌糊涂, 用js写到行内样式上 导致无法在业务层修改。

想到用函数劫持适配方法然后不执行框架的 执行我自定义的,完美解决了这个问题。

上代码
此处是封装的两个方法,采用了劫持原方法并不执行的方式

    methods: {
	      // getTableHeight劫持者
	      hijacker() {
	        let that = this
	        return function () {
	          that.getTableHeight()
	        }
	      },
	      // 劫持处理
	      hijackFn(obj, method, fun) {
	        let orig = obj[method];
	        obj[method] = fun(orig);
	      },
	      getTableHeight函数就是我自定义的函数。当有调用被劫持目标时 将不会执行被劫持的函数 而去执行自   己处理的函数
	      that.getTableHeight(){
       ..............
      }
    }

在生命周期函数中调用
因getTableHeight在组件ref名为crud内部对象源用this.$refs.crud传入。getTableHeight为劫持目标函数。this.hijacker为劫持后需要执行的函数

    mounted() {
       this.hijackFn(this.$refs.crud, 'getTableHeight', this.hijacker);
    }

如果你希望劫持目标而且还需要执行被劫持的目标函数可以这样写

      hijackFn(obj, method, fun) {
        let orig = obj[method];
        obj[method] = fun(orig);
      },
      hijacker(orig) {
        let that = this
        return function () {
          that.getTableHeight()
          orig()   //劫持绑定时 未被改变this指向的函数已经传入,直接执行即可
        }
      },

本质上就是覆盖原函数 并在覆盖之前记录原函数,完成劫持操作的。在一些执行通用函数时在不改变原有函数的业务中 可能会有帮助。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值