M - F: 9am - 5pm Sat: 10am - 3pm Sun: By Appointment

Lady Lake 352-830-2882​

M - F: 9am - 4pm Sat: 10am - 3pm Sun: By Appointment

Get In Touch

Get In Touch

7x Winner of Ocala's Best Golf Cart Dealership

Now in Two Convenient Central Florida Locations

Where to Find Us

Visit our Ocala showroom or our Lady Lake location - same great inventory and service.

304 Oak St, Lady Lake, FL 32159, USA

Lady Lake

Address

304 Oak Street

Lady Lake, FL 32159

Contact

Hours

Mon - Fri: 9am - 4pm

​​Saturday: 10am - 3pm

​Sunday: By Appointment

Socials

Downtown Ocala

Address

1919 NE Jacksonville Rd

STE 103, Ocala, FL 34470

Contact

Hours

Mon - Fri: 9am - 5pm

​​Saturday: 10am - 3pm

​Sunday: By Appointment

Socials

1919 NE Jacksonville Rd ste 103, Ocala, FL 34470, USA

Now in Two Convenient Central Florida Locations

Where to Find Us

Visit our Ocala showroom or our Lady Lake location - same great inventory and service.

Downtown Ocala

1919 NE Jacksonville Rd ste 103, Ocala, FL 34470, USA

Address

1919 NE Jacksonville Rd

STE 103, Ocala, FL 34470

Contact

Hours

Mon - Fri: 9am - 5pm

​​Saturday: 10am - 3pm

​Sunday: By Appointment

Socials

Lady Lake

304 Oak St, Lady Lake, FL 32159, USA

Address

304 Oak Street

Lady Lake, FL 32159

Contact

Hours

Mon - Fri: 9am - 4pm

​​Saturday: 10am - 3pm

​Sunday: By Appointment

Socials

CURRENTLY SUPPORTING

Areas We Serve

  • The Villages

  • Lady Lake

  • Leesburg

  • Ocala

  • Calesa

  • OTOW

  • Downtown Ocala/

    The Woodfields

  • Stone Creek

  • Belleview

  • Dunnellon

  • Gainesville

  • Crystal River

  • and more...

CURRENTLY SUPPORTING

Areas We Serve

  • The Villages

  • Lady Lake

  • Leesburg

  • Ocala

  • Calesa

  • OTOW

  • Downtown Ocala/

    The Woodfields

  • Stone Creek

  • Belleview

  • Dunnellon

  • Gainesville

  • Crystal River

  • and more...

(function() { // Only run this script once the DOM is fully loaded document.addEventListener('DOMContentLoaded', function() { // Get DOM elements const track = document.querySelector('.tc-track'); const cards = Array.from(document.querySelectorAll('.tc-card')); const prevButton = document.querySelector('.tc-prev'); const nextButton = document.querySelector('.tc-next'); // Configuration options const autoplaySpeed = 4000; // Time between slides in milliseconds const transitionSpeed = 500; // Slide transition speed in milliseconds // Responsive settings const cardsToShow = window.innerWidth < 768 ? 1 : 3; const cardWidth = cards[0].offsetWidth + 20; // card width + margin // State variables let currentIndex = 0; let isTransitioning = false; let autoplayInterval; /** * Initialize the carousel */ function initCarousel() { // Set initial position updateCarousel(); // Start autoplay startAutoplay(); } /** * Update carousel position based on current index */ function updateCarousel() { // Calculate position const position = -1 * currentIndex * cardWidth; track.style.transform = `translateX(${position}px)`; // Prevent multiple clicks during transition isTransitioning = true; setTimeout(() => { isTransitioning = false; }, transitionSpeed); } /** * Go to a specific slide index * @param {number} index - The slide index to navigate to */ function goToSlide(index) { if (isTransitioning) return; // Ensure index is within bounds currentIndex = index; if (currentIndex > cards.length - cardsToShow) { currentIndex = cards.length - cardsToShow; } if (currentIndex < 0) { currentIndex = 0; } updateCarousel(); resetAutoplay(); } /** * Navigate to the previous slide */ function goToPrevSlide() { if (isTransitioning) return; goToSlide(currentIndex - 1); } /** * Navigate to the next slide */ function goToNextSlide() { if (isTransitioning) return; // Handle wrapping around to the first slide if (currentIndex >= cards.length - cardsToShow) { goToSlide(0); } else { goToSlide(currentIndex + 1); } } /** * Start the autoplay interval */ function startAutoplay() { autoplayInterval = setInterval(goToNextSlide, autoplaySpeed); } /** * Reset the autoplay timer */ function resetAutoplay() { clearInterval(autoplayInterval); startAutoplay(); } // Set up event listeners // Navigation button events prevButton.addEventListener('click', goToPrevSlide); nextButton.addEventListener('click', goToNextSlide); // Pause autoplay on hover const carouselWrapper = document.querySelector('.tc-wrapper'); carouselWrapper.addEventListener('mouseenter', () => { clearInterval(autoplayInterval); }); carouselWrapper.addEventListener('mouseleave', () => { startAutoplay(); }); // Handle window resize window.addEventListener('resize', () => { const newCardsToShow = window.innerWidth < 768 ? 1 : 3; // Only update if the number of visible cards changed if (newCardsToShow !== cardsToShow) { // Temporarily disable transitions for repositioning cards.forEach(card => { card.style.transition = 'none'; }); // Reset position after a brief delay setTimeout(() => { cards.forEach(card => { card.style.transition = 'transform 0.3s ease, box-shadow 0.3s ease'; }); goToSlide(0); }, 50); } }); // Initialize the carousel initCarousel(); }); })();
(function() { // Only run this script once the DOM is fully loaded document.addEventListener('DOMContentLoaded', function() { // Get DOM elements const track = document.querySelector('.tc-track'); const cards = Array.from(document.querySelectorAll('.tc-card')); const prevButton = document.querySelector('.tc-prev'); const nextButton = document.querySelector('.tc-next'); // Configuration options const autoplaySpeed = 4000; // Time between slides in milliseconds const transitionSpeed = 500; // Slide transition speed in milliseconds // Responsive settings const cardsToShow = window.innerWidth < 768 ? 1 : 3; const cardWidth = cards[0].offsetWidth + 20; // card width + margin // State variables let currentIndex = 0; let isTransitioning = false; let autoplayInterval; /** * Initialize the carousel */ function initCarousel() { // Set initial position updateCarousel(); // Start autoplay startAutoplay(); } /** * Update carousel position based on current index */ function updateCarousel() { // Calculate position const position = -1 * currentIndex * cardWidth; track.style.transform = `translateX(${position}px)`; // Prevent multiple clicks during transition isTransitioning = true; setTimeout(() => { isTransitioning = false; }, transitionSpeed); } /** * Go to a specific slide index * @param {number} index - The slide index to navigate to */ function goToSlide(index) { if (isTransitioning) return; // Ensure index is within bounds currentIndex = index; if (currentIndex > cards.length - cardsToShow) { currentIndex = cards.length - cardsToShow; } if (currentIndex < 0) { currentIndex = 0; } updateCarousel(); resetAutoplay(); } /** * Navigate to the previous slide */ function goToPrevSlide() { if (isTransitioning) return; goToSlide(currentIndex - 1); } /** * Navigate to the next slide */ function goToNextSlide() { if (isTransitioning) return; // Handle wrapping around to the first slide if (currentIndex >= cards.length - cardsToShow) { goToSlide(0); } else { goToSlide(currentIndex + 1); } } /** * Start the autoplay interval */ function startAutoplay() { autoplayInterval = setInterval(goToNextSlide, autoplaySpeed); } /** * Reset the autoplay timer */ function resetAutoplay() { clearInterval(autoplayInterval); startAutoplay(); } // Set up event listeners // Navigation button events prevButton.addEventListener('click', goToPrevSlide); nextButton.addEventListener('click', goToNextSlide); // Pause autoplay on hover const carouselWrapper = document.querySelector('.tc-wrapper'); carouselWrapper.addEventListener('mouseenter', () => { clearInterval(autoplayInterval); }); carouselWrapper.addEventListener('mouseleave', () => { startAutoplay(); }); // Handle window resize window.addEventListener('resize', () => { const newCardsToShow = window.innerWidth < 768 ? 1 : 3; // Only update if the number of visible cards changed if (newCardsToShow !== cardsToShow) { // Temporarily disable transitions for repositioning cards.forEach(card => { card.style.transition = 'none'; }); // Reset position after a brief delay setTimeout(() => { cards.forEach(card => { card.style.transition = 'transform 0.3s ease, box-shadow 0.3s ease'; }); goToSlide(0); }, 50); } }); // Initialize the carousel initCarousel(); }); })();
(function() { // Only run this script once the DOM is fully loaded document.addEventListener('DOMContentLoaded', function() { // Get DOM elements const track = document.querySelector('.tc-track'); const cards = Array.from(document.querySelectorAll('.tc-card')); const prevButton = document.querySelector('.tc-prev'); const nextButton = document.querySelector('.tc-next'); // Configuration options const autoplaySpeed = 4000; // Time between slides in milliseconds const transitionSpeed = 500; // Slide transition speed in milliseconds // Responsive settings const cardsToShow = window.innerWidth < 768 ? 1 : 3; const cardWidth = cards[0].offsetWidth + 20; // card width + margin // State variables let currentIndex = 0; let isTransitioning = false; let autoplayInterval; /** * Initialize the carousel */ function initCarousel() { // Set initial position updateCarousel(); // Start autoplay startAutoplay(); } /** * Update carousel position based on current index */ function updateCarousel() { // Calculate position const position = -1 * currentIndex * cardWidth; track.style.transform = `translateX(${position}px)`; // Prevent multiple clicks during transition isTransitioning = true; setTimeout(() => { isTransitioning = false; }, transitionSpeed); } /** * Go to a specific slide index * @param {number} index - The slide index to navigate to */ function goToSlide(index) { if (isTransitioning) return; // Ensure index is within bounds currentIndex = index; if (currentIndex > cards.length - cardsToShow) { currentIndex = cards.length - cardsToShow; } if (currentIndex < 0) { currentIndex = 0; } updateCarousel(); resetAutoplay(); } /** * Navigate to the previous slide */ function goToPrevSlide() { if (isTransitioning) return; goToSlide(currentIndex - 1); } /** * Navigate to the next slide */ function goToNextSlide() { if (isTransitioning) return; // Handle wrapping around to the first slide if (currentIndex >= cards.length - cardsToShow) { goToSlide(0); } else { goToSlide(currentIndex + 1); } } /** * Start the autoplay interval */ function startAutoplay() { autoplayInterval = setInterval(goToNextSlide, autoplaySpeed); } /** * Reset the autoplay timer */ function resetAutoplay() { clearInterval(autoplayInterval); startAutoplay(); } // Set up event listeners // Navigation button events prevButton.addEventListener('click', goToPrevSlide); nextButton.addEventListener('click', goToNextSlide); // Pause autoplay on hover const carouselWrapper = document.querySelector('.tc-wrapper'); carouselWrapper.addEventListener('mouseenter', () => { clearInterval(autoplayInterval); }); carouselWrapper.addEventListener('mouseleave', () => { startAutoplay(); }); // Handle window resize window.addEventListener('resize', () => { const newCardsToShow = window.innerWidth < 768 ? 1 : 3; // Only update if the number of visible cards changed if (newCardsToShow !== cardsToShow) { // Temporarily disable transitions for repositioning cards.forEach(card => { card.style.transition = 'none'; }); // Reset position after a brief delay setTimeout(() => { cards.forEach(card => { card.style.transition = 'transform 0.3s ease, box-shadow 0.3s ease'; }); goToSlide(0); }, 50); } }); // Initialize the carousel initCarousel(); }); })();

Call, text or email us for more info about our products and services.

At JB Golf Carts, we are committed to providing our customers with exceptional service and competitive pricing.

JB Golf Carts LLC

ADDRESS

FOLLOW US


© 2025. JB Golf Carts.

All Rights Reserved.