一个简单的函数消灭业务代码的低级错误

平常的前端开发业务代码中,咱们常常都须要调试数据,因此要常常更改某些参数的初始化数据,或者更改过程当中的数据。javascript

可是不少时候,改了数据调试完以后就忘记改回去了,某个调试的场景是依赖一个参数的修改还好,可是须要依赖几个参数的修改,就很容易漏改回去了。前端

举两个例子:java

1、咱们有一个按钮来触发弹窗的打开,而控制弹窗显隐为变量showDialog,初始化值为false,可是产品说弹窗里面的样式有点问题,因此咱们设置了showDialog的值为true而后修改内容(由于不可能每次都点击按钮来打开看弹窗效果),最后修改完再将showDialog设置回false。git

//伪代码
var showDialog = false;  //控制窗口显隐,调试须要依赖其变量值
btn.onclick = () => {
  showDialog = true; 
}

2、咱们有个抽奖的活动,逻辑是请求接口以后拿到抽奖的prize_id以后,对比prize_id的内容,而后决定在视图中显示出来,可是咱们须要调试某个抽奖结果的内容,固然不会叫接口改返回的prize_id了,因此咱们可能会改传入显示模块的值。github

//伪代码
fetch().then(prize_id => {
  showResult(prize_id)  //显示抽奖结果,调试须要依赖其传入值
})

function showResult(prize_id){
  //显示抽奖结果的代码
}

问题就在于,不少时候咱们最后忘了改回去,就会出现弹窗直接打开了、每次抽奖都抽中某个奖品的结果了,这种低级错误是不该该犯的,可是我也见过某些app真的直接这样上了测试的代码到生产环境。babel

因此在这些业务代码中,我相信也没什么人会作构建前的校验脚本或者单元测试的,因此咱们须要一个简单的函数来控制变量的赋值,来避免这种低级错误。app

特地写了一个简单的包:https://github.com/ershing/de...函数

用法:单元测试

//引入包dev-debugger
import DevDebugger from 'dev-debugger'
//初始化dgb实例来控制变量的测试值
let dbg = new DevDebugger({ debug: true })
//绑定获取替换的方法,也能够直接调用dbg.debugVal
let _r = dbg.debugVal.bind(dbg)

实例有两个方法:debugVal和debugCaseTag测试

/*
  debugVal(pro, dev)
  @params 传入第一参数为生产值,第二参数为调试值
*/
//也能够绑定方便后面调用
let _r = dbg.debugVal.bind(dbg)


/*
  debugCaseTag(pro, tag)
  @params 传入第一参数为生产值,第二参数为自命名的惟一标签名称
*/
//前提须要配合初始化的传参
let dbg = new DevDebugger({ 
  debug: true,
  caseName: 'testPrize1',  //调试的用例
  cases: {  //用例参数集
    'testPrize1': {
      'myPrize': 3   //标签名称对应的调试值
    },
    'testPrize2': {
      'myPrize': 6   //标签名称对应的调试值
    }
  }
})

//也能够绑定方便后面调用 
let _rt = dbg.debugCaseTag.bind(dbg)

因此上面的例子能够这样写:

1、控制showDialog的变量值

//伪代码
var showDialog = _r(false, true);  //debug时值为true
btn.onclick = () => {
  showDialog = true; 
}

2、控制传入显隐函数的值

//伪代码
fetch().then(prize_id => {
  showResult(_r(prize_id, 3))  //debug时为3
})

function showResult(prize_id){
  //显示抽奖结果的代码
}

固然上面也能够用debugCaseTag方法来将调试的值放在初始化的函数当中。

然而,在咱们构建代码的时候,固然不想有任何调试的代码和调试的值的,因此我又写了一个babel插件:https://github.com/ershing/ba...

用法:

//修改babel.config.js文件
module.exports = {
  "plugins": 
  process.env.NODE_ENV === "production" 
  ? ["babel-plugin-dev-debugger"] 
  : []
}

注意:

使用这个babel插件的话,须要在各自文件中import包dev-debugger(也利于单文件组件的独立调试),并且不要将实例方法赋值出去,能够直接dbg.debugVal或dbg.debugCaseTag使用,也能够bind以后_t或_rt使用,但不要再赋值给其余变量。

个人博客好久没怎么写了,回头看看之前写的技术文章就像垃圾同样:www.ershing.cn

相关文章
相关标签/搜索