Coder Social home page Coder Social logo

js-7's Introduction

JS-7

Кешины посты с котиками, которые вы помогли ему сделать, стали обретать космическую популярность и набирать кучу лайков и комментариев. Все это случилось, потому что появился адаптив для мобильных устройств, а как мы знаем, очень много пользователей открывают веб-приложения с мобильных устройств. С отображением лайков проблем не возникает, однако, с отображением комментариев возникли сложности. Во первых, из-за того, что комментариев очень много, загрузка и отрисовка страницы стала занимать очень много времени, некоторые пользователи не хотят читать все комментарии, но, все равно, вынуждены ждать их загрузки. Во вторых, страница начала подвисать при скролле из-за большого количества node в DOM.

В связи с этими проблемами Кеша в очередной раз обращается к вам за помощью, он знает, что вы изучили взаимодействие с DOM через JS и теперь сможете оптимизировать его страницу, и решить возникшие проблемы.

Подготовка:

  • Для выполнения данной задачи разрешается брать предыдущее задание HTML-CSS-6. Если стили, до сих пор, применяются к сложным, составным селекторам, самое время переделать их на классы, с ними будет легче работать.

  • В файле index.js появился объект поста, с которым вам предстоит плотно поработать. В полях этого объекта содержится информация о самом посте, а также - массив комментариев.

  • Обратите внимание, в массиве комментариев встречаются комментарии, которые содержат вложенные комментарии.

  • Для того чтобы лучше разобраться, что за объект поста перед вами, можете посмотреть на него в браузере, открыв index.html и введя в консоль имя объекта поста (post)

Задача:

  1. Всю информацию для странички нужно брать из объекта post (включая картинки), пора избавиться от статических данных. Начать следует с информации о самом посте. Количество лайков и комментариев также должно динамически считаться

    (!ВАЖНО: дочерние комментарии считаются за отдельные комментарии и учитываются в общем количестве комментариев. Даты должны выводиться в человекочитаемом, привычном формате).

  2. Изначально, при открытии страницы, количество комментариев должно быть не более 10. При прокручивании комментариев вниз они должны постепенно добавляться на изначальное количество комментариев.

    (Если изначально на странице 5 комментариев, то каждый раз, при достижении последнего из N * 5 комментариев, должны добавляться еще 5 комментариев).

  3. Комментарий, который имеет подкомментарии, должен быть выделен отдельным цветом. А при нажатии на него должны появляться вложенные в него комментарии. При повторном нажатии - они должны скрываться.

  4. ⭐(+2 балла): Если количество динамически подгруженных комментариев становится больше 50, то комментарии из начала должны удаляться, то есть на странице всегда должно быть не больше 50 комментариев. А при прокручивание вверх, к началу комментариев, они должны появляться сверху и исчезать снизу. Чтобы получилась, своеобразная, двухсторонняя подгрузка.

js-7's People

Contributors

egornmv avatar aleksandra-ms avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.