💡 An editor is ready below the article—experiment freely!

Updated: 2026年5月31日

Project Todo

Original task (JA): TODO追加

📌

Conclusion

Project Todo — free browser-based JavaScript (DOM) practice

■ What this exercise teaches inputの値とボタンクリックで、ulにliを追加する処理を書いてください。

Why it matters in real projects

フォームの値取得とDOM操作を組み合わせます。 Similar patterns appear daily in code review and production UI work.

Step-by-step workflow

1. Read the guide and understand the goal of "Project Todo" 2. Review the JavaScript (DOM) editor pane and start from the starter code 3. Open hints if stuck; compare your diff with the sample solution 4. Click Run and inspect preview/console output 5. Auto-check looks for output containing: addEventListener, appendChild, createElement. 6. After success, continue with adjacent exercises in the same category

Core concept explained

フォームの値取得とDOM操作を組み合わせます。

Technical focus

Key JavaScript APIs: document.getElementById, document.createElement, addEventListener.

Hint before you peek at the solution

createElement, appendChild, value

Sample solution walkthrough

JavaScript APIs used: document.getElementById, document.createElement, addEventListener. Verify spelling and async/await usage. Explanation: フォームの値取得とDOM操作を組み合わせます。 Hint recap: createElement, appendChild, value

Solution code

📝 Sample code
document.getElementById('add')?.addEventListener('click', () => {
  const input = document.getElementById('todo');
  const ul = document.getElementById('list');
  if (input?.value && ul) {
    const li = document.createElement('li');
    li.textContent = input.value;
    ul.appendChild(li);
    input.value = '';
  }
});

Common mistakes for this exact task

・Skipping the hint: createElement, appendChild, value ・getElementById returns null if the id string differs by even one character

Troubleshooting

Q: Preview does not change after Run A: Ensure you edited the JavaScript (DOM) pane and clicked Run. Q: Looks correct but check fails A: Auto-check looks for output containing: addEventListener, appendChild, createElement. Look for typos, full-width spaces, or unclosed tags. Q: Console shows errors A: Open DevTools Console and fix bracket/quote mismatches at the reported line. Q: Hard to type on mobile A: Use landscape mode or continue on desktop—the same URL keeps progress in localStorage.

Interview / portfolio tips

・Explain the techniques in "Project Todo" in your own words within 30 seconds ・Practice walking through each line of the sample solution on a whiteboard ・Connect this task to a real component you would ship ・Mention responsive or accessibility trade-offs ・Describe when you use: document.getElementById, document.createElement, addEventListener

What to do after you pass

Move to the next exercise in the project track, then continue the learning roadmap at /en/learning/project/.

Keywords

Free hands-on exercise covering TODO追加, project, 中級, document.getElementById, document.createElement, addEventListener, project todo—search-friendly guide for Project Todo.

🧪 Try it here — safe to break things

Use the editor below to write code and preview instantly.

Jump to editor

■ Exercise task

inputの値とボタンクリックで、ulにliを追加する処理を書いてください。

Hint if stuck

createElement, appendChild, value

30pt

TODO追加

inputの値とボタンクリックで、ulにliを追加する処理を書いてください。

エラーをクリックで該当行をハイライト。✕=エラー ⚠=警告 ›=ログ。

Roadmap · All guides

Deep dive

"Project Todo" is a 中級-level JavaScript (DOM) exercise. inputの値とボタンクリックで、ulにliを追加する処理を書いてください。 Run it in-browser with automatic checking.

フォームの値取得とDOM操作を組み合わせます。 Similar patterns appear daily in code review and production UI work.

Pair this with the project roadmap. Exercise #69 reinforces core project skills.

Step-by-step workflow

  1. Read the guide and understand the goal of "Project Todo"
  2. Review the JavaScript (DOM) editor pane and start from the starter code
  3. Open hints if stuck; compare your diff with the sample solution
  4. Click Run and inspect preview/console output
  5. Auto-check looks for output containing: addEventListener, appendChild, createElement.
  6. After success, continue with adjacent exercises in the same category

How to read the sample solution

JavaScript APIs used: document.getElementById, document.createElement, addEventListener. Verify spelling and async/await usage. Explanation: フォームの値取得とDOM操作を組み合わせます。 Hint recap: createElement, appendChild, value

Real-world & career relevance

Todo, counter, and timer apps are common live-coding tasks and strong portfolio pieces.

Common mistakes

  • Skipping the hint: createElement, appendChild, value
  • getElementById returns null if the id string differs by even one character
  • Keeping state only in DOM
  • Double-binding event listeners
  • Storing secrets in localStorage

Troubleshooting

Preview does not change after Run
Ensure you edited the JavaScript (DOM) pane and clicked Run.
Looks correct but check fails
Auto-check looks for output containing: addEventListener, appendChild, createElement. Look for typos, full-width spaces, or unclosed tags.
Console shows errors
Open DevTools Console and fix bracket/quote mismatches at the reported line.
Hard to type on mobile
Use landscape mode or continue on desktop—the same URL keeps progress in localStorage.

Interview & portfolio tips

  • Explain the techniques in "Project Todo" in your own words within 30 seconds
  • Practice walking through each line of the sample solution on a whiteboard
  • Connect this task to a real component you would ship
  • Mention responsive or accessibility trade-offs
  • Describe when you use: document.getElementById, document.createElement, addEventListener

Glossary

localStorage
Persistent key-value storage in the browser.
setTimeout
Run a function after a delay.
State
App data like counts held in one place.

Keywords covered on this page

Free hands-on exercise covering TODO追加, project, 中級, document.getElementById, document.createElement, addEventListener, project todo—search-friendly guide for Project Todo.

Related dev tools

Learning roadmap

Learning roadmap →

Related exercises

Frequently asked questions

Is "TODO追加" free?

This exercise is free and runs entirely in your browser. No account or credit card required.

Difficulty and time?

"TODO追加" is level "中級". Read the guide first; beginners can usually finish within 30 minutes. Allow 5–15 minutes per exercise. Use hints, then the solution if stuck.

What after a correct answer?

After a correct answer, use "Next exercise". When you finish a category, continue on the learning roadmap.

Works on mobile?

Works on mobile browsers, but typing code is easier on a desktop.

Where are other exercises?

All exercises: /en/learn/ with category filters.

Key takeaway for "TODO追加"?

フォームの値取得とDOM操作を組み合わせます。 Hint: createElement, appendChild, value

Where does project fit?

Todo, counter, and timer apps are common live-coding tasks and strong portfolio pieces.

Step-by-step for "Project Todo"?

1. Read the guide and understand the goal of "Project Todo"
2. Review the JavaScript (DOM) editor pane and start from the starter code
3. Open hints if stuck; compare your diff with the sample solution
4. Click Run and inspect preview/console output
5. Auto-check looks for output containing: addEventListener, appendChild, createElement.
6. After success, continue with adjacent exercises in the same category

How to read the sample solution?

JavaScript APIs used: document.getElementById, document.createElement, addEventListener. Verify spelling and async/await usage.

Explanation: フォームの値取得とDOM操作を組み合わせます。

Hint recap: createElement, appendChild, value

Something is not working?

Preview does not change after Run → Ensure you edited the JavaScript (DOM) pane and clicked Run.
Looks correct but check fails → Auto-check looks for output containing: addEventListener, appendChild, createElement. Look for typos, full-width spaces, or unclosed tags.
Console shows errors → Open DevTools Console and fix bracket/quote mismatches at the reported line.
Hard to type on mobile → Use landscape mode or continue on desktop—the same URL keeps progress in localStorage.

Career / interview angle?

Explain the techniques in "Project Todo" in your own words within 30 seconds Practice walking through each line of the sample solution on a whiteboard Connect this task to a real component you would ship Mention responsive or accessibility trade-offs Describe when you use: document.getElementById, document.createElement, addEventListener

Can I change the starter code?

Yes—if it works. Understanding the starter first, then adding minimal diffs, speeds up learning.

What do the points mean?

30pt is a difficulty hint, not a score you must maximize.