Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 21.06.2021, 21:35
Интересующийся
Отправить личное сообщение для javascript888 Посмотреть профиль Найти все сообщения от javascript888
 
Регистрация: 07.05.2021
Сообщений: 16

Как Реализуйте описанную функцию normalizeArr. Потестируйте ее работу.
Нехватка элементов в массиве при создании таблицы
Пусть у нас дан вот такой одномерный массив:
let arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
Пусть теперь мы хотим сделать из него двухмерный массив с 4-мя элементами в каждом подмассиве.
После применения функции convertArr у нас получится следующий двухмерный массив:
let arr = [[1, 2, 3, 4], [5, 6, 7, 8], [9]];
Как вы видите, в последнему подмассиву не хватило элементов и в нем оказалось только число 9.
Если передать такой двухмерный массив в функцию createTableByArr, то она создаст неправильную таблицу - в последнем ряду таблицы будет не четыре td, а один.
Для решения проблемы сделаем функцию normalizeArr, которая первый параметром будет принимать двухмерный массив, вторым параметром - количество элементов в подмассиве, а третьим - заполнитель.
Своим результатом функция должна возвращать "нормализованный" массив: массив, последний элемент которого будет содержать нужное количество элементов. Если этих элементов изначально было меньше, чем нужно функция будет добавлять нужное количество элементов-заполнителей.
Смотрите пример работы функции:
let arr = [[1, 2, 3, 4], [5, 6, 7, 8], [9]]; // выведет [[1, 2, 3, 4], [5, 6, 7, 8], [
9, '-', '-', '-']]:
console.log(normalizeArr(arr, 4, '-'));
Тогда код для создания таблицы из одномерного массива станет выглядеть так:
let arr = [1, 2, 3, 4, 5, 6, 7, 8, 9]; let cols = 4; let twoDimArr = convertArr(arr, cols); let normalTwoDimArr = normalizeArr(twoDimArr, cols, '');
let table = createTableByArr(normalTwoDimArr);

Реализуйте описанную функцию normalizeArr. Потестируйте ее работу.
Ответить с цитированием
  #2 (permalink)  
Старый 21.06.2021, 21:35
Интересующийся
Отправить личное сообщение для javascript888 Посмотреть профиль Найти все сообщения от javascript888
 
Регистрация: 07.05.2021
Сообщений: 16

<!DOCTYPE HTML>
<html>
<head>
    <meta charset="utf-8">
    <title>focusout</title>
</head>
<body>

    <script>
        function normalizeArr(arr, cols, box) {
            let lastElem = arr.pop();
            for (let i = 0; i < cols; i++) {
                if (lastElem[i] == undefined) {
                    lastElem[i] = box;}
            }
            arr.push(lastElem);
            return arr;
        }
        console.log(normalizeArr(arr, 4, '-'));

    </script>
</body>
</html
Ответить с цитированием
  #3 (permalink)  
Старый 21.06.2021, 21:56
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,121

javascript888,
<script>
        let arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
        function normalizeArr(arr, cols, box) {
            let length = cols - (arr.length % cols || cols);
            for (; length--; ) arr.push(box);
            length = arr.length / cols;
            return Array.from({length}, (_, i) => arr.slice(i *= cols, i + cols));
        }
        document.write(JSON.stringify(normalizeArr(arr, 4, '-')));
    </script>

Последний раз редактировалось рони, 21.06.2021 в 23:12.
Ответить с цитированием
  #4 (permalink)  
Старый 21.06.2021, 22:06
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,121

javascript888,
<script>
        let arr = [[1, 2, 3, 4], [5, 6, 7, 8], [9]];
        function normalizeArr(arr, cols, box) {
            return Array.from(arr, (a, i) => (i = a.length) == cols ? a : (a.length = cols,a.fill(box, i, cols)));
        }
        document.write(JSON.stringify(normalizeArr(arr, 4, '-')));
    </script>
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Как вызвать свою функцию из «чужого» кода в Java Script, не переписывая «чужой» код? korobochkin Библиотеки/Тулкиты/Фреймворки 2 19.07.2014 16:17
Как вы относитесь к наркоманам? Maxmaxmaximus7 Оффтопик 7 05.02.2014 13:29
Расширение для Safari. Как вызвать функцию из popover в global page? housewm Opera, Safari и др. 0 21.12.2013 06:07
как реализовать свою функцию к переменной czp Общие вопросы Javascript 2 01.01.2012 19:52
как реализовать передачу функции в функцию?? czp Общие вопросы Javascript 10 29.11.2011 19:21