Vue中两个组件相似,代码重构

在Vue项目开发中,一种不良的开发习惯是,除了将某些工具方法抽取出来之外,所有的业务逻辑都堆积在.vue文件中,即使某两个.vue文件中有重复出现的代码。

可以考虑将这些重复的代码抽取到某个模块,即某个.js文件中。

// sett.js

/**
 * 某两个Vue组件中,有大约60%的代码是重复的,为了消除重复,特将重复出现的方法抽取到该模块。
 * 注意:那两个Vue中的data()里的变量,如果在两个页面都出现了,变量名称一定要一模一样!
 * 如果做不到,那么本文的重构方法不适合你!
 */
export default class Sett {
  /**
   * 在哪个.vue文件中import了该模块,vueObject就代表那个.vue对象
   */
  constructor(vueObject) {
    this.vueObject = vueObject;
  }
  
  querySettInfos(current){
    console.log('[sett.js]进入querySettInfos()');
    let vueObj = this.vueObject;

    // vueObj可以直接读取或修改.vue文件中的data数据
  }
  
  // 注意:方法之间没有逗号
  someMethod(){
  }

}

某个.vue文件:

<script>
import Sett from "@/module/sett";
export default {
    data() {
        return {
          sett: null,
        };
    },
    methods: {
        doQuery(page) {
          this.sett.querySettInfos(page);
        },
    },
    created() {
        this.sett = new Sett(this);
    },
    mounted() {
    }
};
</script>

其他.vue文件也类似,从而达到代码重用的目的。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值