重构反应使用效果删除重复的否则

发布于 2025-01-23 09:15:46 字数 1077 浏览 1 评论 0原文

我有以下使用

我想对其进行重构,如果行请参阅代码,请删除所有这些else

useEffect(() => {
    if(country === "WW") {
        setIsDisable(true);
    } else if (country === "GB") {
        setIsDisable(false);
    } else if (country === "DE") {
        setIsDisable(false);
    } else if (country === "FR") {
        setIsDisable(false);
    } else if (country === "BR") {
        setIsDisable(false);
    } else if (country === "US") {
        setIsDisable(false);
    } else if (country === "IT") {
        setIsDisable(false);
    } else if (country === "US") {
        setIsDisable(false);
    } else if (country === "ES") {
        setIsDisable(false);
    } else if (country === "MX") {
        setIsDisable(false);
    }
  }, [country]);

请参阅国家:gbdefrbrusitus /code>,esmx共享相同的setIsdisable(false)

如何在1行代码中写入相同的代码whitout重复相同否则,如果

I have the following useEffect

I want to refactor it, removing all these else if lines

See the code

useEffect(() => {
    if(country === "WW") {
        setIsDisable(true);
    } else if (country === "GB") {
        setIsDisable(false);
    } else if (country === "DE") {
        setIsDisable(false);
    } else if (country === "FR") {
        setIsDisable(false);
    } else if (country === "BR") {
        setIsDisable(false);
    } else if (country === "US") {
        setIsDisable(false);
    } else if (country === "IT") {
        setIsDisable(false);
    } else if (country === "US") {
        setIsDisable(false);
    } else if (country === "ES") {
        setIsDisable(false);
    } else if (country === "MX") {
        setIsDisable(false);
    }
  }, [country]);

As you can see the country: GB, DE, FR, BR, US, IT, US, ES and MX sharing the same setIsDisable(false)

How would you write in 1 line of code whitout repeating the same else if ?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

戏蝶舞 2025-01-30 09:15:46
useEffect(() => {
   setIsDisable(country === "WW");
}, [country]);

如果您想验证

useEffect(() => {
   if (country === "WW")
      setIsDisable(true);
   else if (["GB", "DE", "FR", "BR", "US", "IT", "ES", "MX"].includes(country))
      setIsDisable(false);
}, [country]);
useEffect(() => {
   setIsDisable(country === "WW");
}, [country]);

if you want to validate

useEffect(() => {
   if (country === "WW")
      setIsDisable(true);
   else if (["GB", "DE", "FR", "BR", "US", "IT", "ES", "MX"].includes(country))
      setIsDisable(false);
}, [country]);
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文