switch语句的多次调用问题

clipboard.png
例如我有个图上2个switch方法处理不同的业务 但type类型是一套,此时每次添加一个新场景都要swtich一遍 感觉很重复 这种情况我改如何设计switchHandler方法 才能我写一次swtich就可以处理不同情况?

clipboard.png

clipboard.png

感谢几位层主提供的思路 为了抽离这个switch 会破坏代码的连续性 得不偿失的感觉

阅读 4.3k
1 个回答

这个可以这么来,套用某大神的一句话,“抽取固定的,封装变化的”。
像这个type属于固定的,type对于不同业务的处理是变化的,所以你可以这么设计。

var type1 = {
    switch1Handler: function () {
        console.log('handler1 in type1');
    },

    switch2Handler: function () {
        console.log('handler2 in type1');
    }
};
var type2 = {
    switch1Handler: function () {
        console.log('handler1 in type2');
    },

    switch2Handler: function () {
        console.log('handler2 in type2');
    }
};

var switch1 = function (type) {
    if (type.hasOwnProperty('switch1Handler'))
        type.switch1Handler();
    else
        return false;
};

var switch2 = function (type) {
    if (type.hasOwnProperty('switch2Handler'))
        type.switch2Handler();
    else
        return false;
};

switch1(type1);//handler1 in type1
switch1(type2);//handler1 in type2
switch2(type1);//handler2 in type1
switch2(type2);//handler2 in type2

//意思也就是switch1和switch2并不用知道type到底是谁,只要type实现了各自需要的方法即可
//你那个业务就写成函数好了,然后可以在各自的类型中,根据业务的不同分别实现业务函数接口
//这些的最大好处在于,你某个type对与某个业务的处理变了,只需要在当前type下修改即可,不用污染其他type的代码

可能说的不对,大神轻喷。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题