From b56b5c642a0806cae795b6dedea2667b744899d2 Mon Sep 17 00:00:00 2001 From: Daniil888-m Date: Mon, 25 Nov 2024 14:33:46 +0300 Subject: [PATCH 1/2] task 4 completed --- index.html | 1 + js/main.js | 95 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 96 insertions(+) diff --git a/index.html b/index.html index 2eed49a..78b2916 100644 --- a/index.html +++ b/index.html @@ -234,6 +234,7 @@

Изображение успешно загруже

Не удалось загрузить данные

+ diff --git a/js/main.js b/js/main.js index e69de29..7ce13f4 100644 --- a/js/main.js +++ b/js/main.js @@ -0,0 +1,95 @@ +const NAMES = [ + 'Кристина', + 'Игорь', + 'Зина', + 'Петруша', + 'Макс', + 'Кирилл', + 'Алекс', + 'Коля', + 'Ксения', + 'Алина' +]; +const DESCRIPTIONS = [ + 'Солнечный берег с белым песком и пальмами.', + 'Ночной город с огнями и движением автомобилей.', + 'Улыбающиеся дети, играющие в парке.', + 'Закат над горами с яркими оранжевыми и красными оттенками.', + 'Стейк на гриле с овощами на стороне.', + 'Старый замок на вершине холма, окруженный туманом.', + 'Лесная тропинка среди осенних деревьев с разноцветной листвой.', + 'Пара, прогуливающаяся по мосту, держа друг друга за руки.', + 'Домашний офис с приятной атмосферой и растениями.', + 'Уютный кафе с чашкой кофе и книгой на столе.', + 'Дети, строящие снеговика на зимнем дворе.', + 'Спокойное озеро с отражением облаков на воде.', + 'Уличный рынок с яркими фруктами и овощами.', + 'Групповой снимок друзей на пляже.', + 'Кошка, спящая на окне в солнечный день.' +]; +const MESSAGES = [ + 'Всё отлично!', + 'В целом всё неплохо.Но не всё.', + 'Когда вы делаете фотографию, хорошо бы убирать палец из кадра.В конце концов это просто непрофессионально.', + 'Моя бабушка случайно чихнула с фотоаппаратом в руках и у неё получилась фотография лучше.', + 'Я поскользнулся на банановой кожуре и уронил фотоаппарат на кота и у меня получилась фотография лучше.', + 'Лица у людей на фотке перекошены, как будто их избивают.Как можно было поймать такой неудачный момент ? !' +]; +function getRandomInt(min, max) { + min = Math.ceil(min); + max = Math.floor(max); + const randomInt = Math.floor(Math.random() * (max - min + 1)) + min; + return randomInt; +} +function getUniqueId(min, max) { + const receivedId = []; + + return function () { + if (receivedId.length >= (max - min + 1)) { + return receivedId[receivedId.length - 1]; + } + let currentId = getRandomInt(min, max); + while (receivedId.includes(currentId)) { + currentId = getRandomInt(min, max); + } + receivedId.push(currentId); + return currentId; + }; +} +function getRandomElement(elements) { + return elements[getRandomInt(0, elements.length - 1)]; +} + +function createPhotos() { + const getPhotoId = getUniqueId(1, 25); + const getCommentId = getUniqueId(1, 1000); + const photos = []; + + for (let i = 0; i < 25; i++) { + const photoId = getPhotoId(); + const comments = []; + + for (let j = 0; j < getRandomInt(0, 30); j++) { + const commentId = getCommentId(); + const comment = { + id: commentId, + avatar: `img/avatar-${getRandomInt(1, 6)}.svg`, + message: getRandomElement(MESSAGES), + name: getRandomElement(NAMES), + }; + comments.push(comment); + } + const photo = { + id: photoId, + url: `photos/${photoId}.jpg`, + description: getRandomElement(DESCRIPTIONS), + likes: getRandomInt(15, 200), + comments: comments + }; + + photos.push(photo); + } + + return photos; +} +createPhotos(); From 17ff33d3e1b8beaabda6d86f52898dc29c40cf56 Mon Sep 17 00:00:00 2001 From: Daniil888-m Date: Mon, 25 Nov 2024 15:06:14 +0300 Subject: [PATCH 2/2] refactored the code --- js/main.js | 55 +++++++++++++++++++++++++++--------------------------- 1 file changed, 28 insertions(+), 27 deletions(-) diff --git a/js/main.js b/js/main.js index 7ce13f4..d50da5a 100644 --- a/js/main.js +++ b/js/main.js @@ -59,37 +59,38 @@ function getUniqueId(min, max) { function getRandomElement(elements) { return elements[getRandomInt(0, elements.length - 1)]; } +const getPhotoId = getUniqueId(1, 25); +const getCommentId = getUniqueId(1, 1000); +function createPhoto() { -function createPhotos() { - const getPhotoId = getUniqueId(1, 25); - const getCommentId = getUniqueId(1, 1000); - const photos = []; + const photoId = getPhotoId(); + const comments = []; - for (let i = 0; i < 25; i++) { - const photoId = getPhotoId(); - const comments = []; - - for (let j = 0; j < getRandomInt(0, 30); j++) { - const commentId = getCommentId(); - const comment = { - id: commentId, - avatar: `img/avatar-${getRandomInt(1, 6)}.svg`, - message: getRandomElement(MESSAGES), - name: getRandomElement(NAMES), - }; - comments.push(comment); - } - const photo = { - id: photoId, - url: `photos/${photoId}.jpg`, - description: getRandomElement(DESCRIPTIONS), - likes: getRandomInt(15, 200), - comments: comments + for (let j = 0; j < getRandomInt(0, 30); j++) { + const commentId = getCommentId(); + const comment = { + id: commentId, + avatar: `img/avatar-${getRandomInt(1, 6)}.svg`, + message: getRandomElement(MESSAGES), + name: getRandomElement(NAMES), }; - - photos.push(photo); + comments.push(comment); } + const photo = { + id: photoId, + url: `photos/${photoId}.jpg`, + description: getRandomElement(DESCRIPTIONS), + likes: getRandomInt(15, 200), + comments: comments + }; + return photo; +} + +function getPhotos() { + const photos = Array.from({ length: 25 }, createPhoto); return photos; } -createPhotos(); + +getPhotos(); +