Skip to content

Commit aa7047b

Browse files
committed
add list
1 parent b9f3d29 commit aa7047b

File tree

4 files changed

+259
-0
lines changed

4 files changed

+259
-0
lines changed
Lines changed: 64 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,64 @@
1+
<!DOCTYPE html>
2+
<html lang="en">
3+
<head>
4+
<meta charset="UTF-8">
5+
<title>LocalStorage</title>
6+
<link rel="stylesheet" href="style.css">
7+
</head>
8+
<body>
9+
<!--
10+
Fish SVG Cred:
11+
https://thenounproject.com/search/?q=fish&i=589236
12+
-->
13+
14+
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" x="0px" y="0px" viewBox="0 0 512 512" enable-background="new 0 0 512 512" xml:space="preserve"><g><path d="M495.9,425.3H16.1c-5.2,0-10.1,2.9-12.5,7.6c-2.4,4.7-2.1,10.3,0.9,14.6l39,56.4c2.6,3.8,7,6.1,11.6,6.1h401.7 c4.6,0,9-2.3,11.6-6.1l39-56.4c3-4.3,3.3-9.9,0.9-14.6C506,428.2,501.1,425.3,495.9,425.3z M449.4,481.8H62.6L43,453.6H469 L449.4,481.8z"/><path d="M158.3,122c7.8,0,14.1-6.3,14.1-14.1V43.4c0-7.8-6.3-14.1-14.1-14.1c-7.8,0-14.1,6.3-14.1,14.1v64.5 C144.2,115.7,150.5,122,158.3,122z"/><path d="M245.1,94.7c7.8,0,14.1-6.3,14.1-14.1V16.1c0-7.8-6.3-14.1-14.1-14.1C237.3,2,231,8.3,231,16.1v64.5 C231,88.4,237.3,94.7,245.1,94.7z"/><path d="M331.9,122c7.8,0,14.1-6.3,14.1-14.1V43.4c0-7.8-6.3-14.1-14.1-14.1s-14.1,6.3-14.1,14.1v64.5 C317.8,115.7,324.1,122,331.9,122z"/><path d="M9.6,385.2c5.3,2.8,11.8,1.9,16.2-2.2l50.6-47.7c56.7,46.5,126.6,71.9,198.3,71.9c0,0,0,0,0,0 c87.5,0,169.7-36.6,231.4-103.2c5-5.4,5-13.8,0-19.2c-61.8-66.5-144-103.2-231.4-103.2c-72,0-142.2,25.6-199,72.5l-50-47.1 c-4.4-4.1-10.9-5-16.2-2.2c-5.3,2.8-8.3,8.7-7.4,14.6l11.6,75L2.2,370.6C1.3,376.5,4.2,382.4,9.6,385.2z M380.9,230.8 c34.9,14.3,67.2,35.7,95.3,63.6c-10.1,10-20.8,19.2-31.9,27.5c-22.4-3.3-29.6-8.8-30.7-9.7c-4-5.7-11.8-7.7-18.1-4.4 c-6.9,3.6-9.5,12.2-5.9,19.1c1.9,3.5,7.3,10.3,22.4,16c-10.1,5.7-20.5,10.7-31.1,15.1C352.4,320.2,352.4,268.6,380.9,230.8z M36.3,255.6l29.4,27.7c5.3,5,13.6,5.1,19.1,0.3c53.2-47.6,120.7-73.7,190-73.7c26.9,0,53.2,3.9,78.5,11.3 c-29.3,44.6-29.3,102,0,146.6c-25.3,7.4-51.6,11.3-78.5,11.3c-69,0-136.3-26-189.4-73.2c-2.7-2.4-13.4-6.3-19.1,0.3l-30.1,28.3 l5.7-40C42.2,293,36.3,255.6,36.3,255.6z"/><circle cx="398.8" cy="273.8" r="14.1"/></g></svg>
15+
16+
<div class="wrapper">
17+
<h2>LOCAL TAPAS</h2>
18+
<p></p>
19+
<ul class="plates">
20+
<li>Loading Tapas...</li>
21+
</ul>
22+
<form class="add-items">
23+
<input type="text" name="item" placeholder="Item Name" required>
24+
<input type="submit" value="+ Add Item">
25+
</form>
26+
</div>
27+
28+
<script>
29+
const addItems = document.querySelector('.add-items');
30+
const itemsList = document.querySelector('.plates');
31+
const items = [];
32+
33+
function addItem(e){
34+
e.preventDefault();
35+
// console.log('hello');
36+
const text = this.querySelector('[name=item]').value;
37+
const item = {
38+
text: text,
39+
done: false
40+
}
41+
// console.log(item);
42+
items.push(item); //add item
43+
// console.table(items); //check
44+
populateList(items, itemsList);
45+
this.reset(); //clear item
46+
}
47+
48+
function populateList(plates = [], populateList){
49+
populateList.innerHTML = plates.map((plate, i)=>{
50+
return `
51+
<li>
52+
<label for="">${plate.text}</label>
53+
</li>
54+
`;
55+
}).join('');
56+
}
57+
58+
59+
addItems.addEventListener('submit', addItem);
60+
</script>
61+
62+
63+
</body>
64+
</html>
Lines changed: 77 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,77 @@
1+
<!DOCTYPE html>
2+
<html lang="en">
3+
<head>
4+
<meta charset="UTF-8">
5+
<title>LocalStorage</title>
6+
<link rel="stylesheet" href="style.css">
7+
</head>
8+
<body>
9+
<!--
10+
Fish SVG Cred:
11+
https://thenounproject.com/search/?q=fish&i=589236
12+
-->
13+
14+
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" x="0px" y="0px" viewBox="0 0 512 512" enable-background="new 0 0 512 512" xml:space="preserve"><g><path d="M495.9,425.3H16.1c-5.2,0-10.1,2.9-12.5,7.6c-2.4,4.7-2.1,10.3,0.9,14.6l39,56.4c2.6,3.8,7,6.1,11.6,6.1h401.7 c4.6,0,9-2.3,11.6-6.1l39-56.4c3-4.3,3.3-9.9,0.9-14.6C506,428.2,501.1,425.3,495.9,425.3z M449.4,481.8H62.6L43,453.6H469 L449.4,481.8z"/><path d="M158.3,122c7.8,0,14.1-6.3,14.1-14.1V43.4c0-7.8-6.3-14.1-14.1-14.1c-7.8,0-14.1,6.3-14.1,14.1v64.5 C144.2,115.7,150.5,122,158.3,122z"/><path d="M245.1,94.7c7.8,0,14.1-6.3,14.1-14.1V16.1c0-7.8-6.3-14.1-14.1-14.1C237.3,2,231,8.3,231,16.1v64.5 C231,88.4,237.3,94.7,245.1,94.7z"/><path d="M331.9,122c7.8,0,14.1-6.3,14.1-14.1V43.4c0-7.8-6.3-14.1-14.1-14.1s-14.1,6.3-14.1,14.1v64.5 C317.8,115.7,324.1,122,331.9,122z"/><path d="M9.6,385.2c5.3,2.8,11.8,1.9,16.2-2.2l50.6-47.7c56.7,46.5,126.6,71.9,198.3,71.9c0,0,0,0,0,0 c87.5,0,169.7-36.6,231.4-103.2c5-5.4,5-13.8,0-19.2c-61.8-66.5-144-103.2-231.4-103.2c-72,0-142.2,25.6-199,72.5l-50-47.1 c-4.4-4.1-10.9-5-16.2-2.2c-5.3,2.8-8.3,8.7-7.4,14.6l11.6,75L2.2,370.6C1.3,376.5,4.2,382.4,9.6,385.2z M380.9,230.8 c34.9,14.3,67.2,35.7,95.3,63.6c-10.1,10-20.8,19.2-31.9,27.5c-22.4-3.3-29.6-8.8-30.7-9.7c-4-5.7-11.8-7.7-18.1-4.4 c-6.9,3.6-9.5,12.2-5.9,19.1c1.9,3.5,7.3,10.3,22.4,16c-10.1,5.7-20.5,10.7-31.1,15.1C352.4,320.2,352.4,268.6,380.9,230.8z M36.3,255.6l29.4,27.7c5.3,5,13.6,5.1,19.1,0.3c53.2-47.6,120.7-73.7,190-73.7c26.9,0,53.2,3.9,78.5,11.3 c-29.3,44.6-29.3,102,0,146.6c-25.3,7.4-51.6,11.3-78.5,11.3c-69,0-136.3-26-189.4-73.2c-2.7-2.4-13.4-6.3-19.1,0.3l-30.1,28.3 l5.7-40C42.2,293,36.3,255.6,36.3,255.6z"/><circle cx="398.8" cy="273.8" r="14.1"/></g></svg>
15+
16+
<div class="wrapper">
17+
<h2>LOCAL TAPAS</h2>
18+
<p></p>
19+
<ul class="plates">
20+
<li>Loading Tapas...</li>
21+
</ul>
22+
<form class="add-items">
23+
<input type="text" name="item" placeholder="Item Name" required>
24+
<input type="submit" value="+ Add Item">
25+
</form>
26+
</div>
27+
28+
<script>
29+
const addItems = document.querySelector('.add-items');
30+
const itemsList = document.querySelector('.plates');
31+
const items = JSON.parse(localStorage.getItem('items')) || [];
32+
33+
function addItem(e) {
34+
e.preventDefault();
35+
const text = (this.querySelector('[name=item]')).value;
36+
const item = {
37+
text,
38+
done: false
39+
};
40+
41+
items.push(item);
42+
populateList(items, itemsList);
43+
localStorage.setItem('items', JSON.stringify(items));
44+
this.reset();
45+
}
46+
47+
function populateList(plates = [], platesList) {
48+
platesList.innerHTML = plates.map((plate, i) => {
49+
return `
50+
<li>
51+
<input type="checkbox" data-index=${i} id="item${i}" ${plate.done ? 'checked' : ''} />
52+
<label for="item${i}">${plate.text}</label>
53+
</li>
54+
`;
55+
}).join('');
56+
}
57+
58+
function toggleDone(e) {
59+
if (!e.target.matches('input')) return; // skip this unless it's an input
60+
const el = e.target;
61+
const index = el.dataset.index;
62+
items[index].done = !items[index].done;
63+
localStorage.setItem('items', JSON.stringify(items));
64+
populateList(items, itemsList);
65+
}
66+
67+
addItems.addEventListener('submit', addItem);
68+
itemsList.addEventListener('click', toggleDone);
69+
70+
populateList(items, itemsList);
71+
72+
</script>
73+
74+
75+
</body>
76+
</html>
77+
Lines changed: 77 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,77 @@
1+
<!DOCTYPE html>
2+
<html lang="en">
3+
<head>
4+
<meta charset="UTF-8">
5+
<title>Speech Synthesis</title>
6+
<link href='https://fonts.googleapis.com/css?family=Pacifico' rel='stylesheet' type='text/css'>
7+
<link rel="stylesheet" href="style.css">
8+
</head>
9+
<body>
10+
11+
<div class="voiceinator">
12+
13+
<h1>The Voiceinator 5000</h1>
14+
15+
<select name="voice" id="voices">
16+
<option value="">Select A Voice</option>
17+
</select>
18+
19+
<label for="rate">Rate:</label>
20+
<input name="rate" type="range" min="0" max="3" value="1" step="0.1">
21+
22+
<label for="pitch">Pitch:</label>
23+
24+
<input name="pitch" type="range" min="0" max="2" step="0.1">
25+
<textarea name="text">Hello! I love JavaScript 👍</textarea>
26+
<button id="stop">Stop!</button>
27+
<button id="speak">Speak</button>
28+
29+
</div>
30+
31+
<script>
32+
const msg = new SpeechSynthesisUtterance();
33+
let voices = [];
34+
const voicesDropdown = document.querySelector('[name="voice"]');
35+
const options = document.querySelectorAll('[type="range"], [name="text"]');
36+
const speakButton = document.querySelector('#speak');
37+
const stopButton = document.querySelector('#stop');
38+
msg.text = document.querySelector('[name="text"]').value;
39+
40+
function populateVoices() {
41+
voices = this.getVoices();
42+
voicesDropdown.innerHTML = voices
43+
.filter(voice => voice.lang.includes('zh-TW'))
44+
.map(voice => `<option value="${voice.name}">${voice.name} (${voice.lang})</option>`)
45+
.join('');
46+
}
47+
48+
function setVoice() {
49+
msg.voice = voices.find(voice => voice.name === 'Google 國語(臺灣)');
50+
toggle();
51+
}
52+
53+
function toggle(startOver = true) {
54+
speechSynthesis.cancel();
55+
if (startOver) {
56+
speechSynthesis.speak(msg);
57+
}
58+
}
59+
60+
function setOption() {
61+
console.log(this.name, this.value);
62+
msg[this.name] = this.value;
63+
msg.voice = voices.find(voice => voice.name === 'Google 國語(臺灣)');
64+
toggle();
65+
}
66+
67+
speechSynthesis.addEventListener('voiceschanged', populateVoices);
68+
voicesDropdown.addEventListener('change', setVoice);
69+
options.forEach(option => option.addEventListener('change', setOption));
70+
speakButton.addEventListener('click', toggle);
71+
stopButton.addEventListener('click', () => toggle(false));
72+
73+
</script>
74+
75+
</body>
76+
</html>
77+
<!-- Google 國語(臺灣) (zh-TW) -->

23 - Speech Synthesis/index-y.html

Lines changed: 41 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,41 @@
1+
<!DOCTYPE html>
2+
<html lang="en">
3+
<head>
4+
<meta charset="UTF-8">
5+
<title>Speech Synthesis</title>
6+
<link href='https://fonts.googleapis.com/css?family=Pacifico' rel='stylesheet' type='text/css'>
7+
<link rel="stylesheet" href="style.css">
8+
</head>
9+
<body>
10+
11+
<div class="voiceinator">
12+
13+
<h1>The Voiceinator 5000</h1>
14+
15+
<select name="voice" id="voices">
16+
<option value="">Select A Voice</option>
17+
</select>
18+
19+
<label for="rate">Rate:</label>
20+
<input name="rate" type="range" min="0" max="3" value="1" step="0.1">
21+
22+
<label for="pitch">Pitch:</label>
23+
24+
<input name="pitch" type="range" min="0" max="2" step="0.1">
25+
<textarea name="text">Hello! I love JavaScript 👍</textarea>
26+
<button id="stop">Stop!</button>
27+
<button id="speak">Speak</button>
28+
29+
</div>
30+
31+
<script>
32+
const msg = new SpeechSynthesisUtterance();
33+
let voices = [];
34+
const voicesDropdown = document.querySelector('[name="voice"]');
35+
const options = document.querySelectorAll('[type="range"], [name="text"]');
36+
const speakButton = document.querySelector('#speak');
37+
const stopButton = document.querySelector('#stop');
38+
</script>
39+
40+
</body>
41+
</html>

0 commit comments

Comments
 (0)