Svelte: привязка данных для сборщика аккордеона

Я играю вокруг Svelte (JS), чтобы создать приложение для медицинского обследования. Мои данные о {категориях, тестах, подтестах}

Мне нужно использовать сборщик аккордеонных подтестов для подачи резюме.

Выбор дизайна заключается в объединении категорий и уровней тестов из-за объемности. Пользователь выбирает категорию + тест, а аккордеон показывает подтесты, которые можно выбрать.

Я не очень знаком с двусторонним связыванием данных с Svelte. Я пробовал это, но приводит к ошибке типа: "ctx.selected" не определен.

<section>
  <h1>Pick subtests you need in accordion list</h1>

  <div class="accordion">
    {#each cats_tests as ct, ctidx }
      <div class="wrapper">
        <h2 class="ct-heading">
         <label>
           <input bind:group='selected' value={ ctidx }  type=checkbox />
           <span>{ ctidx }: { ct.name }</span>
         </label>
        </h2>
        {#if selected[ctidx] }
          {#each ct.subtests as sub, subidx }
            <div transition:fade>
              <h3 class="subtest-heading">
                <label for="ct-{ctidx}-sub-{subidx}">
                  <input  id="ct-{ctidx}-sub-{subidx}" type="checkbox" />
                  <span>{ subidx }: { sub.name }</span>
                </label>
              </h3>
            </div>
          {/each}
       {/if}
      </div>
    {/each}
  </div>
</section>

<script>
  import { fade } from 'svelte-transitions'

  export default {
    transitions: { fade},

    oncreate() {

    },

    data() {
      return {
        cats_tests: [
          {
            name: 'Cat A - Test 1',
            subtests: [
              { name: 'subtest-s'},
              { name: 'subtest-t'},
              { name: 'subtest-u'}
            ]
          }, {
            name: 'Cat A - Test 2',
              subtests: [
          { name: 'subtest-v'},
          { name: 'subtest-w'},
          { name: 'subtest-x'} ,
          { name: 'subtest-y'}
        ]
          }, {
            name: 'Cat B - Test 3',
            subtests: [
              { name: 'subtest-z'}
            ]
         }
       ]
     }
    }
  }
</script>

<style>
  h2.ct-heading {
    background-color: #d1e1f1;
  }

  h3.subtest-heading {
    padding-left: 15%;
  }

</style>

Вопросы:

  1. Как это исправить?
  2. Как получить выбранные подтесты в других частях приложения, не запрашивая сервер? Учтите, что я использую плагин svelte-routing и магазин

Спасибо за ответы.

1 ответ

В принципе:

одна ошибка (отсутствует) добавить selected: [] в разделе данных, конечно...

и обнаружение того, какой заголовок выбран:

{#if selected.indexOf(ctidx) > -1 }
  {#each ct.subtests as sub, subidx }
    <div transition:fade>
      // ...
    </div>
   {/each}
 {/if}

И это сработало для меня!

Другие вопросы по тегам