Historic Site
About This Attraction
The Grand Place in Brussels is a central square surrounded by opulent guildhalls, the Town Hall, and the Kings House or Breadhouse. This iconic site is known for its stunning architecture, with buildings that date back to the late 17th century. Each structure has its own unique history and architectural style, which contributes to the squares charm. Its a popular tourist destination, and visitors often come to admire the intricate facades and enjoy various cultural events held throughout the year.
For those planning a visit, knowing some Grand Place travel information can be helpful. The square is easily accessible by public transport, including buses and metro services. Its also within walking distance of other major attractions in Brussels. Events such as the Flower Carpet, held every two years in August, draw large crowds, so its advisable to plan accommodations well in advance if visiting during these times. The Grand Place is an essential stop for anyone wanting to experience the historical and cultural heart of Brussels.
Location Details
Address
Grand Place, 1000 Brussels, Belgium
Visitor Information
Pricing & Ratings
Ticket Prices
Adult
Free
Child
Free
Student
Free
Senior
Free
Opening Hours & Booking
Open
Days
Open 24 hours
Hours
Monday to Sunday: 24 hours
Seasonality
Open all year round
Booking
Booking Required?
No
Advance Booking
Not applicable days recommended
Nearby Attractions
Manneken Pis is a famous bronze statue located in the heart of Brussels, Belgium. Created…
Learn More
The Royal Palace in Brussels is a prominent landmark and the official palace of the…
Learn More
The Atomium is a unique and iconic structure located in Brussels, Belgium. Built for the…
Learn More
Antwerp Zoo, located in the heart of Antwerp, Belgium, is one of the oldest animal…
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
The Citadel of Dinant is a historic fortress located in the town of Dinant, Belgium.…
Learn More
The Collegiate Church of Notre Dame in Dinant is a notable landmark with its striking…
Learn More
Maison Leffe, located in Dinant, Belgium, is a museum dedicated to the history and production…
Learn More
The Nieuwe Kerk in Delft is a historic church that stands as a significant landmark…
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';
}
});
});
}
});