Home / Business / Report: California needs...

Report: California needs nearly 1 million more affordable homes for low-income households

Left 20% AI estimate Right 10%
California, United States
March 10, 2026 (Updated: March 10, 2026) 2 min read 1 source 0 Center Negative AI Assisted
Report: California needs nearly 1 million more affordable homes for low-income households
AI-Generated Content — Learn More

TheWkly Analysis

A new report by the National Low Income Housing Coalition (NLIHC, a nonprofit advocating for affordable housing policies) states that California needs close to 1 million more low-income homes. The state has just 25 available and affordable rental homes for every 100 extremely low-income households, defined as those making 30% or less of the area's median income. No state in the country has enough affordable homes, but California is one of the worst off, with only Oregon and Nevada having fewer available homes per household. Construction workers are building an apartment complex for an affordable housing project in Bakersfield on May 29, 2024. Most of California's extremely low-income households are spending more than half their income on housing, contributing to high rates of housing instability and homelessness.

Multiple perspectives analyzed from 0 sources
What this means for you:
  • Extremely low-income households in California spend more than half their income on rent, forcing many to cut essentials like food and healthcare.
  • Homelessness rises among vulnerable populations in cities like Bakersfield, displacing families and straining local shelters.
  • Workers in construction and low-wage jobs face instability, limiting their ability to relocate for better opportunities within the state.

Key Entities

  • National Low Income Housing Coalition Organization

    Nonprofit organization that researches and advocates for policies to increase affordable rental housing for low-income Americans.

  • California Place

    U.S. state facing one of the nation's worst shortages of affordable homes relative to extremely low-income households.

  • Bakersfield Place

    City in California where an affordable housing apartment complex project is under construction as of May 29, 2024.

  • Extremely low income Concept

    Household income category defined as 30% or less of the area's median income, used to assess need for affordable rentals.

Multi-Perspective Analysis

Left-Leaning View

Emphasizes systemic failure in providing housing as a right, calling for more government intervention and funding to combat inequality.

Centrist View

Presents factual data on shortages and ongoing projects like Bakersfield, highlighting the scale without assigning blame.

Right-Leaning View

Views it as a supply issue due to overregulation, advocating market-driven solutions and reduced red tape for developers.

Source & Verification

Source: CalMatters RSS

Status: AI Processed

Want to dive deeper?

We've prepared an in-depth analysis of this story with additional context and background.

Featuring Our Experts' Perspectives in an easy-to-read format.

Future Snapshot

See how this story could impact your life in the coming months

Sign In to Generate

Exclusive Member Feature

Create a free account to access personalized Future Snapshots

Future Snapshots show you personalized visions of how insights from this story could positively impact your life in the next 6-12 months.

  • Tailored to your life indicators
  • Clear next steps and action items
  • Save snapshots to your profile

Related Roadmaps

Explore step-by-step guides related to this story, designed to help you apply this knowledge in your life.

Loading roadmaps...

Please wait while we find relevant roadmaps for you.

Your Opinion

What is the biggest barrier to building more affordable homes in California?

Your feedback helps us improve our content.

Support Independent Journalism

If you found this story valuable, consider supporting TheWkly to help us continue delivering quality news.

Comments (0)

Add your comment

Commenting as Guest

No comments yet. Be the first to share your thoughts!

Related Stories

Guatemala USD to GTQ Opening Exchange Rate Reported for March 10
Business March 10, 2026

Guatemala USD to GTQ Opening Exchange Rate Reported for March 10

Infobae reports the dollar opening quote in Guatemala for today, March 10. The article covers...

Raiffeisen Bank to acquire BBVA's Romanian Garanti division for 550 million euros, becoming third-largest bank
Business March 10, 2026

Raiffeisen Bank to acquire BBVA's Romanian Garanti division for 550 million euros, becoming third-largest bank

Raiffeisen Bank International AG (an Austrian banking group operating in Central and Eastern...

Turkestan Region's Economy in Kazakhstan Grows by 113.9%
Business March 10, 2026

Turkestan Region's Economy in Kazakhstan Grows by 113.9%

The economy of Turkestan Region grew by 113.9%. This growth was reported by Kazakhstan Today....

Share this story
// Function to create a roadmap using our consolidated approach function createRoadmap(storyId) { // Show a loading indicator const loadingHtml = `

Creating your roadmap...

This may take a moment

`; document.body.insertAdjacentHTML('beforeend', loadingHtml); // Make the API call to create the roadmap using the enhanced unified approach fetch(`/api/roadmaps/create/${storyId}`, { method: 'POST', headers: { 'Content-Type': 'application/json', 'X-CSRFToken': 'IjdjZTk1OWExMzhlZjRmNjdiZTc5YWQxNDRmNzgxMjUyMjZjNjc1Zjgi.abBkxw.tOteHSv7zJWBIlMHc72p3nfGhDI' } }) .then(response => response.json()) .then(data => { // Remove the loading indicator document.getElementById('loading-overlay').remove(); if (data.success) { // Show success message const successHtml = `

Roadmap Created!

Your learning path has been successfully created.

`; document.body.insertAdjacentHTML('beforeend', successHtml); } else { // Show error message const errorHtml = `

Error

${data.message || 'An error occurred while creating the roadmap.'}

`; document.body.insertAdjacentHTML('beforeend', errorHtml); } }) .catch(error => { // Remove the loading indicator document.getElementById('loading-overlay').remove(); // Show error message const errorHtml = `

Error

An unexpected error occurred. Please try again later.

`; document.body.insertAdjacentHTML('beforeend', errorHtml); console.error('Error creating roadmap:', error); }); } document.addEventListener('DOMContentLoaded', function() { // Auto-mark as read after 10 seconds // Function to load related roadmaps function loadRelatedRoadmaps() { // Load related roadmaps for this story console.log('Loading related roadmaps for story ID: 30006'); fetch('/api/stories/30006/related-roadmaps') .then(response => { if (!response.ok) { throw new Error(`HTTP error! Status: ${response.status}`); } return response.json(); }) .then(data => { console.log('Related roadmaps API response:', data); const container = document.getElementById('roadmaps-container'); if (!container) { console.error('Roadmaps container not found in DOM'); return; } // Clear the loading indicator container.innerHTML = ''; if (data.roadmaps && data.roadmaps.length > 0) { console.log(`Found ${data.roadmaps.length} roadmaps to display`); // Render each roadmap card data.roadmaps.forEach(roadmap => { console.log(`Processing roadmap ID ${roadmap.id}: ${roadmap.title}`); const card = document.createElement('div'); card.className = 'p-4 bg-white rounded-lg border border-blue-200 hover:shadow-md transition-shadow'; let iconType = 'map'; if (roadmap.type === 'career') iconType = 'briefcase'; else if (roadmap.type === 'personal') iconType = 'user'; else if (roadmap.type === 'learning') iconType = 'graduation-cap'; else if (roadmap.type === 'financial') iconType = 'chart-line'; card.innerHTML = `

${roadmap.title}

${roadmap.description || 'Interactive step-by-step guide'}

${roadmap.step_count ? ` ${roadmap.step_count} steps` : ''} ${roadmap.created_by ? ` ${roadmap.created_by}` : ''}
`; container.appendChild(card); }); } else { console.log('No roadmaps found for this story'); // Show "no roadmaps" message with different content for logged in vs not logged in users const isLoggedIn = false; if (isLoggedIn) { container.innerHTML = `

No roadmaps found for this story yet.

Be the first to create one!

`; } else { container.innerHTML = `

Create your own roadmaps!

Sign up to create interactive step-by-step guides for this story and others.

`; } } }) .catch(error => { console.error('Error loading roadmaps:', error); const container = document.getElementById('roadmaps-container'); if (container) { container.innerHTML = `

Unable to load roadmaps at this time.

Error: ${error.message}

`; } }); } // Load roadmaps when page loads loadRelatedRoadmaps(); // Check for "roadmap_created" or "roadmap_updated" URL parameter and reload roadmaps if present const urlParams = new URLSearchParams(window.location.search); if (urlParams.has('roadmap_created') || urlParams.has('roadmap_updated')) { // Small delay to ensure the UI is ready setTimeout(loadRelatedRoadmaps, 500); } // Add event listeners to roadmap creation links to append return parameters document.querySelectorAll('a[href*="create_roadmap_from_story"], a[href*="create-roadmap-from-plan"]').forEach(link => { link.addEventListener('click', function(e) { // Store the current URL to return to this page const returnUrl = window.location.href.split('?')[0] + '?roadmap_created=true'; // Store in sessionStorage sessionStorage.setItem('roadmapReturnUrl', returnUrl); }); }); // Handle reaction buttons const reactionButtons = document.querySelectorAll('.reaction-btn'); reactionButtons.forEach(button => { button.addEventListener('click', function() { const reaction = this.dataset.reaction; const storyId = this.dataset.storyId; // Send reaction to server fetch(`/api/stories/${storyId}/reactions`, { method: 'POST', headers: { 'Content-Type': 'application/json', 'X-CSRFToken': 'IjdjZTk1OWExMzhlZjRmNjdiZTc5YWQxNDRmNzgxMjUyMjZjNjc1Zjgi.abBkxw.tOteHSv7zJWBIlMHc72p3nfGhDI' }, body: JSON.stringify({ reaction_type: reaction }) }) .then(response => response.json()) .then(data => { if (data.success) { // Toggle active state if (data.added) { this.classList.add('border-blue-500', 'bg-blue-50', 'text-blue-700'); } else { this.classList.remove('border-blue-500', 'bg-blue-50', 'text-blue-700'); } // Update count if available const countElement = this.querySelector('.reaction-count'); if (data.count > 0) { if (countElement) { countElement.textContent = `(${data.count})`; } else { const countSpan = document.createElement('span'); countSpan.className = 'reaction-count'; countSpan.textContent = `(${data.count})`; const textElement = this.querySelector('span:not(.text-lg)'); textElement.appendChild(countSpan); } } else if (countElement) { countElement.remove(); } } }) .catch(error => { console.error('Error updating reaction:', error); }); }); }); });