Js 简化代码的基础上解决后台返回字符串类型的Boolean值导致判断错误的问题

正常情况 我们js判断Boolean值可以直接这样写

let mint = false;
if(mint){
  console.log("条件为 true");
}else{
  console.log("条件为 false");
}

在这里插入图片描述
没有任何问题
但有时 后端直接给我们返回了个字符串 这种情况还是不少的 因为有些后端不想处理 就直接这样省事
但却会影响我们的判断结果

let mint = "false";
if(mint){
  console.log("条件为 true");
}else{
  console.log("条件为 false");
}

在这里插入图片描述
因为 mint 是个字符串 那么字符串判断的就是非空了 那他不为空啊 所以条件就成立了 换成Boolean就是true了

这时 有人就会想 改成

if(mint == "true")


那要是后端有时候有返回的是Boolean类型的呢?
又有人想说

if(mint == "true"||mint == true)

我只能说 你这样是可以解决问题 但太丑了 写的 说实话 很多余

我们直接用js中的 eval方法就好了

let mint = "false";
if(eval(mint)){
  console.log("条件为 true");
}else{
  console.log("条件为 false");
}

在这里插入图片描述

let mint = false;
if(eval(mint)){
  console.log("条件为 true");
}else{
  console.log("条件为 false");
}

在这里插入图片描述
可以看到 无论是Boolean还是String都没有任何问题