Nano Hash - криптовалюты, майнинг, программирование

Простая кнопка «Назад» и «Далее» для горизонтальной прокрутки к следующему элементу div jQuery

(Я знаю, что ранее были некоторые вопросы по этой теме, но я не могу заставить это работать в моей ситуации.) Я хочу иметь возможность прокручивать текст по горизонтали, а также использовать «предыдущий Кнопки «Далее» и «Далее» для навигации по тексту (текст разбит на несколько разделов). Я хочу, чтобы пользователь мог переключаться в любое время. Я знаю, что некоторые решения предлагают установить активный класс для видимого div, но, похоже, это не работает с прокруткой.

Создание кнопки «Далее» не кажется проблемой, но я не могу понять, как заставить предыдущую кнопку работать правильно.

Это то, что у меня есть на jsfiddle.

$(document).ready(function(){
$('#next').click(function() {
   var target;
   $(".section").each(function(i, element) {
     target = $(element).offset().left;
     if (target - 10 > $(document).scrollLeft()) {
       return false; 
     }});
   $("html, body").animate({
     scrollLeft: target
}, 500);
});
});

Я также нашел это решение, в котором кнопка «Далее» не работает, но кажется, что она слишком усложняет ее (или, может быть, действительно необходимо добавить больше div и сделать jQuery чрезвычайно трудным для понимания) jsfiddle

    var currentElement = $("#bodytext > div:nth-child(2)");
var onScroll = function () {
    var container = $("#main");
    var bodytext = $("#bodytext");
    var children = $(".section");
    var position = 0;
    for (var i = 0; i < children.length; i++) {
        var child = $(children[i]);
        var childLeft = container.offset().left < child.offset().left;
        if (childLeft) {
            currentElement = child;
            console.log(currentElement);
            return;
        }
    }
};

var scrollToElement = function ($element) {
    var container = $("#main");
    var bodytext = $("#bodytext");
    var children = $(".section");
    var width = 0;
    for (var i = 0; i < children.length; i++) {
        var child = $(children[i]);
        if (child.get(0) == $element.get(0)) {
            if (i === 0) {
                width = 0;
            }
            container.animate({
                scrollLeft: width
            }, 500);
            onScroll();
        }
        if (child.next().length > 0) {
            width += child.next().offset().left - child.offset().left;
        } else {
            width += child.width();
        }
    }
};

var next = function (e) {
    scrollToElement(currentElement);
}

var previous = function (e) {
    var container = $("#main");
    if (currentElement.prev().length > 0) {
        if (container.offset().left == currentElement.prev().offset().left) {
            currentElement = currentElement.prev().prev().length > 0 ? currentElement.prev().prev() : currentElement.prev();
        } else {
            currentElement = currentElement.prev();
        }
    }
    scrollToElement(currentElement);
};

$("#main").scroll(onScroll);
$("#next").click(next);
$("#previous").click(previous);

Вы могли бы подумать, что я могу объединить оба решения, что по какой-то причине не работает в данный момент, но в идеале я хотел бы найти довольно простое/чистое решение jQuery. Если у кого-то есть идеи, это было бы очень признательно. Спасибо!


Ответы:


1

scrollLeft() и scrollTop() работают, ориентируя прокрутку на количество пикселей слева или сверху. Так что, если вы возьмете свою скрипку и пойдете $(document).scrollLeft(500), вы увидите, что осталось движение. То же самое для прокрутки вниз с помощью $(document).scrollTop().

Поэтому я бы попробовал что-то вроде этого:

Дайте кнопкам «предыдущая» и «следующая» один и тот же класс, например #scrollButton, и отслеживайте, где ваш пользователь прокручивал ваш JavaScript.

$('#scrollButton').click(function() {
//logic to find out which button you clicked, perhaps from an ID

//logic here to find out where the user is
   var target = //that location;

//scroll to that location +/- X pixels, depending on which button you clicked...then just use your reassigned target

   $("html, body").animate({
     scrollLeft: target
}, 500);
});

Это сломается, если пользователь использует два вида прокрутки, но если вы начнете прослушивать события прокрутки, вы сможете отслеживать оба.

Ваш вопрос не совсем ясен о том, как вы хотите выполнять прокрутку. Не похоже, что вы еще не пробовали, но, возможно, это поможет вам начать. https://api.jquery.com/scroll/

Вы в основном ищете события и делаете то же самое. Вы прошли большую часть пути!

29.04.2015
  • Спасибо за помощь, стало немного понятнее, что мне нужно делать. Я очень новичок в этом, и на данный момент все это очень запутанно, но все равно спасибо! 30.04.2015
  • Новые материалы

    Кластеризация: более глубокий взгляд
    Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

    Частный метод Python: улучшение инкапсуляции и безопасности
    Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

    Как я автоматизирую тестирование с помощью Jest
    Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

    Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
    В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..