【问题标题】:How to test svelte input attribute agains multiple options如何测试多个选项的苗条输入属性
【发布时间】:2022-01-26 04:16:59
【问题描述】:

我有存储价值和两组数据:

$selectedColor

const productColor = {
   options: [
      {id:0, title: 'white'},
      {id:1, title: 'black'},
      {id:2, title: 'red'},
      {id:3, title: 'yellow'}
   ],
}


const productType = {
   options: [
      {id:0, title: 'somethings', hiddenInColor: 'white'},
      {id:1, title: 'somethings', hiddenInColor: 'black'},
      {
         id:2, 
         title: 'somethings', 
         hiddenInColor: 
        //here should be black AND white
        //problem is I can't understand how to use nested json with disable attribute (see below) 
      }
   ],
}

然后我为产品类型和颜色填充输入(类型:单选)

{#each productType.options as option (option.id)}
            {#if activeTab !== option.hiddenIn}
                <li>
                    <label>
                        <input type="radio" name="name" 
                            value={option.id} 
                            on:change={() => optionHasChanged(option.name, somethings)}
                            disabled={option.hiddenInColor == $selectedColor}
                            bind:group={defaultProductType}>
                        {option.title}
                    </label>
                </li>
            {/if}
        {/each}

我试图 -> 禁用输入 IF $selectedColor == hiddenInColor

我是这样做的->

disabled={option.hiddenInColor == $selectedColor}

而且效果很好。但是...仅当您针对 1 个值进行测试时

我不明白如何一次检查超过 1 种颜色。 所以基本上,使用我的 const productType -> 如果 $selectedColor == 'black' || 我想禁用 id:3 '白色'

有什么建议吗?或者也许有更紧凑的解决方案?谢谢

【问题讨论】:

    标签: javascript json svelte svelte-3 svelte-store


    【解决方案1】:

    实现这一点的最简单方法是使用数组 hiddenInColors 而不是单个标量值:

    const productType = {
       options: [
          {id:0, title: 'somethings', hiddenInColors: ['white']},
          {id:1, title: 'somethings', hiddenInColors: ['black']},
          {id:2, title: 'somethings', hiddenInColors: ['black','white']},
       ],
    }
    

    然后像这样设置禁用选项:

    disabled={option.hiddenInColors.includes($selectedColor)}
    

    【讨论】:

    • 嗨@Thomas Hennes,非常感谢您的努力。但是:disabled={option.hiddenInColors.includes($selectedColor)} 我总是看到一个 TypeError: Cannot read properties of undefined (reading 'includes') $selectedColor 的默认值存在,因为:disabled={option.hiddenInColor == $ selectedColor} 正在工作
    • 这意味着hiddenInColors 未设置或不是数组。检查您的代码是否有拼写错误。请记住,您还必须在数组中设置单一颜色,就像我在回答中所做的那样。
    • 你是对的。有一个错字问题。非常感谢您抽出宝贵时间。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-03-28
    • 1970-01-01
    • 2021-09-19
    • 2019-01-09
    • 2013-07-22
    相关资源
    最近更新 更多