49,013 properties
0 phones
0 emails
0 for sale
71 results · Page 2/2
All (49,013) Self-Storage (6,315) Mobile Home Parks (7,982) Car Washes (7,857) Laundromats (5,362) RV Parks (8,082) Marinas (3,500) Budget Motels (9,891) Mailbox / Pack & Ship (24)
Map:

Clark Fork Storage

3

Missoula, MT · 3305 Clark Fork Way

Self-Storage
Phone Email

Broadway Storage

3

Missoula, MT · 1150 East Broadway Street

Self-Storage
Phone Email

Vigilante Parking and Storage

3

Missoula, MT · 4050 West Broadway Street

Self-Storage
Phone

Knutzion Storage

3

MT · 214 Main Avenue South

Self-Storage
Phone

Continental Drive Storage

3

Butte, MT · 1021 Continental Drive

Self-Storage
Phone

Sentry Storage

3

Butte, MT · 1110 Hayes Avenue

Self-Storage
Phone Email

Rainbow Mini Storage

3

Missoula, MT · 7780 West Riverside Drive

Self-Storage
Phone

Hellgate Canyon Storage

3

Missoula, MT · 730 Clyde Street

Self-Storage
Phone

South Shore Mini Storage

3

Polson, MT · 38109 MT-35

Self-Storage
Phone Email

Four Seasons Storage

3

Stevensville, MT · 23 Stevi Cutoff Road

Self-Storage
Phone

Always Open Storage

3

Belgrade, MT · 154 Countryside Lane

Self-Storage
Phone

Wye West Storage

3

Missoula, MT · 7099 Two Smokes Way

Self-Storage
Phone

Brad's Self Service Storage - West Side

3

Deer Lodge, MT · 411 Washington Street

Self-Storage
Phone

Brad's Self Service Storage - Downtown

3

Deer Lodge, MT · 209 North 2nd Street

Self-Storage
Phone

Brad's Self Service Storage - Eastside

3

Deer Lodge, MT · 64 Sleepy Hollow Lane

Self-Storage
Phone

Lakewood Storage

3

Polson, MT · 41448 Ranch Road

Self-Storage
Phone

Curtis Street Storage

3

Missoula, MT · 101 South Curtis Street

Self-Storage

Al's Mini Storage

3

Billings, MT · 5542 Deadwood Drive

Self-Storage
Phone

Affordable Self Storage

3

MT

Self-Storage
Phone

JLW Storage

3

Fort Benton, MT · 2305 Saint Charles Street

Self-Storage
Phone Email

Southgate Storage

3

Miles City, MT · 501 Parkhill Drive

Self-Storage
Phone
← Prev 2 / 2
// Heat map modes // mapPoints format: [id, lat, lon, category, valuation, data_score, motivated_score] let heatLayer = null; let circleLayer = null; let currentMode = 'markers'; function clearOverlays() { if (heatLayer) { map.removeLayer(heatLayer); heatLayer = null; } if (circleLayer) { map.removeLayer(circleLayer); circleLayer = null; } } function setMapMode(mode) { currentMode = mode; clearOverlays(); // Update button states document.querySelectorAll('.map-mode-btn').forEach(b => b.classList.remove('active')); document.getElementById('btn-' + mode).classList.add('active'); if (mode === 'markers') { markers.addTo(map); return; } map.removeLayer(markers); if (mode === 'density') { // Pure density heatmap const pts = mapPoints.filter(p => p[1] && p[2]).map(p => [p[1], p[2], 1]); heatLayer = L.heatLayer(pts, {radius: 20, blur: 15, maxZoom: 10, max: 5, gradient: {0.2: '#ffffb2', 0.4: '#fd8d3c', 0.6: '#f03b20', 0.8: '#bd0026', 1: '#800026'} }).addTo(map); } else if (mode === 'valuation') { // Circle markers colored by valuation circleLayer = L.layerGroup(); const maxVal = Math.max(...mapPoints.map(p => p[4]).filter(v => v > 0)) || 1; mapPoints.filter(p => p[1] && p[2] && p[4] > 0).forEach(p => { const ratio = Math.min(p[4] / maxVal, 1); const r = Math.round(ratio * 255); const g = Math.round((1 - ratio) * 200); const color = `rgb(${r}, ${g}, 50)`; const radius = 4 + ratio * 10; L.circleMarker([p[1], p[2]], { radius: radius, fillColor: color, color: '#fff', weight: 1, fillOpacity: 0.7 }).bindPopup(`$${(p[4]/1000).toFixed(0)}K`).addTo(circleLayer); }); circleLayer.addTo(map); } else if (mode === 'quality') { // Circle markers colored by data_score circleLayer = L.layerGroup(); mapPoints.filter(p => p[1] && p[2]).forEach(p => { const score = p[5] || 0; const ratio = score / 10; // Green = high, Red = low const r = Math.round((1 - ratio) * 255); const g = Math.round(ratio * 200); const color = `rgb(${r}, ${g}, 50)`; L.circleMarker([p[1], p[2]], { radius: 3 + ratio * 5, fillColor: color, color: '#fff', weight: 0.5, fillOpacity: 0.6 }).addTo(circleLayer); }); circleLayer.addTo(map); } else if (mode === 'motivated') { // Heat map weighted by motivated score const pts = mapPoints.filter(p => p[1] && p[2] && p[6] > 0).map(p => [p[1], p[2], p[6] / 100]); heatLayer = L.heatLayer(pts, {radius: 25, blur: 20, maxZoom: 10, max: 1, gradient: {0.2: '#fff7bc', 0.4: '#fec44f', 0.6: '#fe9929', 0.8: '#d95f0e', 1: '#993404'} }).addTo(map); } }
🔒
Unlock owner contacts for 55,000+ properties
Get Access