Historical Landmark
About This Attraction
The Belfry of Bruges is a medieval bell tower located in the heart of Bruges, Belgium, and it stands as one of the citys most prominent landmarks. This towering structure reaches 83 meters in height and provides visitors with panoramic views of the citys historic center. With a climb of 366 steps to the top, it offers an insight into the architectural brilliance of the Middle Ages. Notably, the belfry houses a carillon with 47 bells that regularly chime, adding a musical element to this important historical site.
For those seeking Belfry of Bruges travel information, its essential to know that the tower is open to the public for tours. Visitors can learn about its history through exhibitions inside the building while appreciating its stunning architecture. The entrance fee is modest, making it accessible for tourists who wish to explore this UNESCO World Heritage site. It is advisable to visit early in the day to avoid large crowds, ensuring a more pleasant experience as you ascend this iconic tower.
Location Details
Address
Markt 7, 8000 Brugge, Belgium
Visitor Information
Pricing & Ratings
Ticket Prices
Adult
12 Euros
Child
Free for children under 6
Student
10 Euros
Senior
10 Euros
Opening Hours & Booking
Open
Days
Monday to Sunday
Hours
9:30 AM - 6:00 PM
Seasonality
Open all year round
Booking
Booking Required?
No, but recommended during peak season
Advance Booking
7 days days recommended
Book Your Visit
*Prices may vary. Check official website for the most up-to-date information.
Nearby Attractions
The Basilica of the Holy Blood in Bruges is a renowned church known for housing…
Learn More
Markt Square in Bruges is the central hub of this historic Belgian city. It is…
Learn More
The Cathedral of Our Lady in Antwerp is a significant landmark known for its stunning…
Learn More
The MAS Museum, located in Antwerp, Belgium, is a striking modern building that focuses on…
Learn More
Antwerp Zoo, located in the heart of Antwerp, Belgium, is one of the oldest animal…
Learn More
The Atomium is a unique and iconic structure located in Brussels, Belgium. Built for the…
Learn More
Manneken Pis is a famous bronze statue located in the heart of Brussels, Belgium. Created…
Learn More
The Grand Place in Brussels is a central square surrounded by opulent guildhalls, the Town…
Learn More
The Royal Palace in Brussels is a prominent landmark and the official palace of the…
Learn More
The Erasmus Bridge, located in Rotterdam, is an architectural landmark known for its unique design.…
Learn More
";
}
// Initialize modal controls
const initModalControls = function() {
console.log('Initializing modal controls');
const modal = document.getElementById('attraction-modal');
const closeBtn = document.querySelector('.attraction-modal-close');
if (closeBtn) {
closeBtn.addEventListener('click', function() {
modal.style.display = 'none';
document.body.style.overflow = '';
});
}
window.addEventListener('click', function(event) {
if (event.target === modal) {
modal.style.display = 'none';
document.body.style.overflow = '';
}
});
// Make attraction cards clickable
const attractionCards = document.querySelectorAll('.attraction-card');
console.log('Found ' + attractionCards.length + ' attraction cards');
attractionCards.forEach(card => {
card.addEventListener('click', function(e) {
openModalWithCardData(this);
});
});
};
// Function to open modal with card data
const openModalWithCardData = function(card) {
// Get data from hidden div
const data = card.querySelector('.attraction-full-data');
if (!data) {
console.error('No attraction data found in card');
return;
}
const modal = document.getElementById('attraction-modal');
if (!modal) {
console.error('Modal element still not found after creation attempt');
return;
}
// Helper function to safely get element text
function getElementText(selector) {
const element = data.querySelector(selector);
return element ? element.textContent : '';
}
try {
// Basic Info
document.getElementById('attraction-modal-title').textContent = getElementText('.attraction-name');
document.getElementById('attraction-modal-type').textContent = getElementText('.attraction-type-full');
document.getElementById('attraction-modal-description').textContent = getElementText('.attraction-description-full');
// Reset all containers to hidden
['attraction-modal-hours-container', 'attraction-modal-price-container',
'attraction-modal-address-container', 'attraction-modal-image-container'].forEach(id => {
const container = document.getElementById(id);
if (container) container.style.display = 'none';
});
// Rating
const ratingText = getElementText('.attraction-rating-full');
if (ratingText) {
const ratingValue = parseFloat(ratingText);
if (!isNaN(ratingValue)) {
const ratingValueEl = document.getElementById('attraction-modal-rating-value');
const ratingFillEl = document.getElementById('attraction-modal-rating-fill');
if (ratingValueEl) ratingValueEl.textContent = ratingValue.toFixed(1) + '/10';
if (ratingFillEl) ratingFillEl.style.width = (ratingValue * 10) + '%';
}
}
// Show the modal
modal.style.display = 'block';
document.body.style.overflow = 'hidden'; // Prevent background scrolling
console.log('Modal opened successfully');
} catch (error) {
console.error('Error opening modal:', error);
}
};
// Try to create the modal
const created = createModal();
console.log('Modal created:', created);
// If not created (already exists), initialize the controls
if (!created) {
initModalControls();
}
// Also initialize distance toggle
const distanceToggle = document.getElementById('distance-unit-toggle');
if (distanceToggle) {
distanceToggle.addEventListener('change', function() {
const showKm = this.checked;
// Update toggle labels
const labels = document.querySelectorAll('.toggle-label');
if (labels.length >= 2) {
labels[0].style.opacity = showKm ? '0.5' : '1';
labels[1].style.opacity = showKm ? '1' : '0.5';
}
// Update all distance displays
document.querySelectorAll('.nearby-attraction-card').forEach(card => {
const kmEl = card.querySelector('.distance-km');
const miEl = card.querySelector('.distance-mi');
if (kmEl && miEl) {
kmEl.style.display = showKm ? 'inline' : 'none';
miEl.style.display = showKm ? 'none' : 'inline';
}
});
});
}
});