Как добавить разрыв строки в цикл Vue JS v-for с помощью CSS


Как добавить разрыв строки в цикл Vue JS v-for с помощью CSS

26.10.2020 09:32:42 Просмотров 3 Источник

Мне нужно отобразить имена в алфавитном порядке, если щелкнуть элемент списка. Я использую Vue.js и гибкая сетка для этого.

У меня есть элемент списка с именем ListAll,

При нажатии на ListAll я должен отобразить все записи, сгруппированные по именам из массива nameList. Я столкнулся с проблемой отображения сгруппированных имен. Я использую Flex Grid для отображения имен. После показа записи, записи B, должны начинаться с новой строки, Но б записи не прорваться к новой линии. Как добавить разрыв строки после каждого набора имен с помощью синтаксиса Vue js, ES6 или CSS?

Я добавил разрыв строки, подобный этому <div class="break"></div>, но он не бьет рекордов.

Записи отображаются в 4 столбцах без разрыва строки с помощью CSS класса flexbox grid следующим образом,

Apples Apricots Avocados Almond
Abiu Berry Bananas Boysenberries 
Blueberries Breadfruit Carambola Cantaloupe 
Cranberries Cherries Custard-Apple

ожидаемый результат:

Apples Apricots Avocados Almond
Abiu 
Berry Bananas Boysenberries Blueberries 
Breadfruit
Carambola Cantaloupe Cranberries Cherries
Custard-Apple

AlphabeticalFruitsName.Вью

<template>
    <div id="wrapper">
        <ul class="listitems">
            <li><a
                href="javascript:;" @click="userSelection('ListAll')">ListAll</a>
            </li>
        </ul>
        <div class="grid-container">
            <div v-for="(name, index) in nameList" :key="name" class="grid-item">
                <ul v-for="letter in alphabets" :key="letter">
                    <li v-if="name.startsWith(letter)"><a>{{ name }}</a></li>
                    <div class="break"></div>
                </ul>
            </div>
        </div>
    </div>
</template>

<script>
export default {
  name: 'AlphabeticalFruitsName',
  data() {
    return {
      nameList: [],
      alphabets: ['A','B','C','D','E','F','G','H','I','J','K','L',
        'M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z',],
      names: [
        { name: 'Apples' },{ name: 'Apricots' },{ name: 'Avocados' },{ name: 'Apple Berry' },
        { name: 'Apple guava' },{ name: 'Almond' },{ name: 'Almond' },{ name: 'African Honeysuckle' },
        { name: 'African Plum' },{ name: 'Abiu' },{ name: 'Bananas' },{ name: 'Boysenberries' },
        { name: 'Blueberries' }, { name: 'Bing Cherry' },{ name: 'Breadfruit' },{ name: 'Cantaloupe' },
        { name: 'Carambola' },{ name: 'Cherimoya' },{ name: 'Cherries' },{ name: 'Cranberries' },
        { name: 'Custard-Apple' },{ name: 'Dates' }, { name: 'Honeysuckle' },{ name: 'Gooseberries' },
        { name: 'Grapefruit' },{ name: 'Grapes' },{ name: 'Guava' },{ name: 'Tangerine' },
        { name: 'Kiwi' },{ name: 'Lychee' },{ name: 'Strawberries' }, { name: 'Watermelon' }],
    };
  },
  methods: {
      userSelection(listItemName) {
      this.nameList = [];
      if (listItemName === 'ListAll') {
        for (const value of this.names) {
          this.nameList.push(value.name);
        }
      }
    },
  },
};
</script>

<style lang="scss" scoped>
.listitems {
display: flex;
justify-content: center;
}

ul {
    list-style-type: none;
}

.grid-container {
    display: grid;
    grid-template-columns: auto auto auto auto;
    padding: 10px;
}

.grid-item {
    text-align: center;
}

.new-line:last-child {
    content: '\a';
    white-space: pre;
}

.break {
    flex-basis: 100%;
    height: 0;
}
</style>
У вопроса есть решение - Посмотреть?

Ответы - Как добавить разрыв строки в цикл Vue JS v-for с помощью CSS / How to Add Line Break in Vue JS v-for loop with CSS

jshrc

26.10.2020 09:41:34

Это проверит каждый элемент после первого, чтобы увидеть, если первая буква текущего имени и предыдущего имени не совпадают, и если нет, то он выведет br. Я предполагаю, что ваш список уже будет в алфавитном порядке.

<div v-for="(name, index) in nameList" :key="name" class="grid-item">
    <ul v-for="alphabet in alphabets" :key="alphabet">
        //a BR or whatever element you need
        <br v-if="i > 0 && nameList[i-1].name.charAt(0) !== name.charAt(0)"/>
        <li v-if="name.startsWith(alphabet)"><a>{{ name }}</a></li>
        <div class="break"></div>
    </ul>
</div>
Помочь в развитии проекта:
Закрыть X