note..
[HTML + Javascript] Wordle 만들어보기
sungjine
2022. 3. 11. 23:34
반응형
어쩌다가 Wordle을 알게 되었다.
하루 한 번만 가능한데 더 하고 싶어서 만들어본다.
Wordle은 하나의 온전한 단어를 맞추는 거지만 이번에 만들어 본건 랜덤 한 영어다.
막 만들어서 코드나 동작이나 마음에는 들지 않지만 가끔 심심풀이로 하기엔 괜찮을 듯싶어 더 수정하진 않는다.
HTML - BODY
<div id="wrapper">
<div id="parent">
<div class="child" id="child0">
<input type="text" id="on0" maxlength="1" onkeyup="input_onkeyup(event);" />
<input type="text" id="tw0" maxlength="1" onkeyup="input_onkeyup(event);" />
<input type="text" id="tr0" maxlength="1" onkeyup="input_onkeyup(event);" />
<input type="text" id="fo0" maxlength="1" onkeyup="input_onkeyup(event);" />
<input type="text" id="fi0" maxlength="1" onkeyup="input_onkeyup(event);" />
</div>
</div>
<button id="btn" onclick="btn_click();">submit</button>
</div>
CSS
#wrapper {
margin: 100px auto 0 auto;
width: 290px;
}
#parent {
width: 290px;
}
.child {
width: 290px;
display: flex;
justify-content: space-between;
margin-bottom: 12px;
}
input {
width: 50px;
height: 50px;
border: none;
background-color: gray;
color: white;
text-align: center;
font-size: 30px;
}
button {
width: 105px;
height: 50px;
font-size: 30px;
}
Javascript
var result = "";
var count = 0;
function btn_click() {
var onE = document.getElementById("on" + count);
var twE = document.getElementById("tw" + count);
var trE = document.getElementById("tr" + count);
var foE = document.getElementById("fo" + count);
var fiE = document.getElementById("fi" + count);
var onV = onE.value;
var twV = twE.value;
var trV = trE.value;
var foV = foE.value;
var fiV = fiE.value;
if (onV === "" || twV === "" || trV === "" || foV === "" || fiV === "") {
alert("모두 입력해주세요.");
return;
}
var match = 0;
if (onV === result[0]) {
match = match + 1;
onE.style.backgroundColor = "#16b316";
} else if (result.indexOf(onV) > -1) {
onE.style.backgroundColor = "#cbbb24";
} else {
onE.style.backgroundColor = "#3c3c3c";
}
if (twV === result[1]) {
match = match + 1;
twE.style.backgroundColor = "#16b316";
} else if (result.indexOf(twV) > -1) {
twE.style.backgroundColor = "#cbbb24";
} else {
twE.style.backgroundColor = "#3c3c3c";
}
if (trV === result[2]) {
match = match + 1;
trE.style.backgroundColor = "#16b316";
} else if (result.indexOf(trV) > -1) {
trE.style.backgroundColor = "#cbbb24";
} else {
trE.style.backgroundColor = "#3c3c3c";
}
if (foV === result[3]) {
match = match + 1;
foE.style.backgroundColor = "#16b316";
} else if (result.indexOf(foV) > -1) {
foE.style.backgroundColor = "#cbbb24";
} else {
foE.style.backgroundColor = "#3c3c3c";
}
if (fiV === result[4]) {
match = match + 1;
fiE.style.backgroundColor = "#16b316";
} else if (result.indexOf(fiV) > -1) {
fiE.style.backgroundColor = "#cbbb24";
} else {
fiE.style.backgroundColor = "#3c3c3c";
}
if (match == 5) {
document.getElementById("on" + count).setAttribute('readonly', true);
document.getElementById("tw" + count).setAttribute('readonly', true);
document.getElementById("tr" + count).setAttribute('readonly', true);
document.getElementById("fo" + count).setAttribute('readonly', true);
document.getElementById("fi" + count).setAttribute('readonly', true);
const node = document.createElement("button");
node.id = "reset";
node.innerHTML = "reset";
node.onclick = reset;
document.getElementById("wrapper").appendChild(node);
document.getElementById("btn").remove();
} else {
addChild();
}
}
function input_onkeyup(event) {
var keyCode = event.keyCode;
var target = event.target;
if (keyCode >= 65 && keyCode <= 90) {
target.value = target.value.toLocaleUpperCase();
} else if (!(keyCode == 8 || keyCode == 9 || keyCode == 16 || keyCode == 27)) {
target.value = "";
alert("영어만 입력해주세요.");
}
}
function addChild() {
document.getElementById("on" + count).setAttribute('readonly', true);
document.getElementById("tw" + count).setAttribute('readonly', true);
document.getElementById("tr" + count).setAttribute('readonly', true);
document.getElementById("fo" + count).setAttribute('readonly', true);
document.getElementById("fi" + count).setAttribute('readonly', true);
count = count + 1;
const node = document.createElement("div");
node.classList.add('child');
node.id = 'child' + count;
node.innerHTML = inputFormat();
document.getElementById("parent").appendChild(node);
}
function reset() {
count = 0;
const btn = document.createElement("button");
btn.id = "btn";
btn.innerHTML = "submit";
btn.onclick = btn_click;
document.getElementById("wrapper").appendChild(btn);
document.getElementById("reset").remove();
var list = document.getElementsByClassName("child");
for (var i = list.length - 1; i >= 0; i--) {
list[i].remove();
}
const node = document.createElement("div");
node.classList.add('child');
node.id = 'child' + count;
node.innerHTML = inputFormat();
document.getElementById("parent").appendChild(node);
resetResult();
}
function inputFormat() {
return "<input type='text' id='on" + count + "' maxlength='1' onkeyup='input_onkeyup(event);'/><input type='text' id='tw" + count + "' maxlength='1' onkeyup='input_onkeyup(event);' /><input type='text' id='tr" + count + "' maxlength='1' onkeyup='input_onkeyup(event);' /><input type='text' id='fo" + count + "' maxlength='1' onkeyup='input_onkeyup(event);' /> <input type='text' id='fi" + count + "' maxlength='1' onkeyup='input_onkeyup(event);'/>"
}
function resetResult() {
result = "";
var characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
var num = 26;
for ( var i = 0; i < 5; i++ ) {
var random = Math.floor(Math.random() * num);
result += characters.charAt(random);
characters = characters.slice(0, random) + characters.slice(random + 1);
num = num - 1;
}
console.log("result : " + result);
}
resetResult();
반응형