Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

コードの修正 #21

Open
wants to merge 18 commits into
base: gh-pages
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
19 changes: 19 additions & 0 deletions assessment.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
body {
color: #000000;
background-color: #FFFF00;
width: 500px;
margin-left: auto;
margin-right: auto;
margin-top: auto;
}

button {
color: #FFFFFF;
padding: 5px 20px;
background-color: brown;
border-style: double;
}

input {
height: 30px;
}
26 changes: 26 additions & 0 deletions assessment.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
<!DOCTYPE html>
<html lang="ja">

<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>assessment</title>
<meta name="twitter:card" content="summary" />
<meta property="og:url" content="https://kensuketachi.github.io/assessment/assessment.html" />
<meta property="og:title" content="あなたのいいところ診断" />
<meta property="og:description" content="kensuketachiが制作した、「あなたのいいところ診断」サイトです。" />
<link rel="stylesheet" href="assessment.css">
</head>

<body>
<h2>あなたのいいところを診断します</h2>
<p>診断したい名前を入れてください</p>
<input type="text" id="user-name" size="40" maxlength="10">
<button id="assessment">診断する</button>
<div id="result-area">診断結果</div>
<div id="tweet-area"></div>
<script src="assessment.js"></script>

</body>

</html>
88 changes: 88 additions & 0 deletions assessment.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
'use strict';
const userNameInput = document.getElementById('user-name');
const assessmentButton = document.getElementById('assessment');
const resultArea = document.getElementById('result-area');
const tweetArea = document.getElementById('tweet-area');

function removeAllChildren(element) {
while (element.firstChild) {
element.removeChild(element.firstChild);
}
}


assessmentButton.onclick = () => {
const userName = userNameInput.value;
if (userName.length === 0) {
return;
}
// 診断エリア
removeAllChildren(resultArea);
const header = document.createElement('h2');
header.innerText = '診断結果';
resultArea.appendChild(header);

const paragraph = document.createElement('p');
const result = assessment(userName);
paragraph.innerText = result;
resultArea.appendChild(paragraph);

// ツイートエリア
removeAllChildren(tweetArea);
const anchor = document.createElement('a');
const hrefValue = 'https://twitter.com/intent/tweet?button_hashtag=' + encodeURIComponent('あなたのいいところ') + '&ref_src=twsrc%5Etfw';
anchor.setAttribute('href', hrefValue);
anchor.setAttribute('class', 'twitter-hashtag-button');
anchor.setAttribute('data-text', result);
anchor.innerText = 'Tweet #あなたのいいところ';
tweetArea.appendChild(anchor);

// Widget.jsの設定
const script = document.createElement('script');
script.setAttribute('src', 'https://platform.twitter.com/widgets.js');
tweetArea.appendChild(script);
}

userNameInput.onkeydown = event => {
if (event.key === 'Enter') {
assessmentButton.onclick()
}
}

const answers = [
'{userName}のいいところは声です。{userName}の特徴的な声は皆を惹きつけ、心に残ります。',
'{userName}のいいところはまなざしです。{userName}に見つめられた人は、気になって仕方がないでしょう。',
'{userName}のいいところは情熱です。{userName}の情熱に周りの人は感化されます。',
'{userName}のいいところは厳しさです。{userName}の厳しさがものごとをいつも成功に導きます。',
'{userName}のいいところは知識です。博識な{userName}を多くの人が頼りにしています。',
'{userName}のいいところはユニークさです。{userName}だけのその特徴が皆を楽しくさせます。',
'{userName}のいいところは用心深さです。{userName}の洞察に、多くの人が助けられます。',
'{userName}のいいところは見た目です。内側から溢れ出る{userName}の良さに皆が気を惹かれます。',
'{userName}のいいところは決断力です。{userName}がする決断にいつも助けられる人がいます。',
'{userName}のいいところは思いやりです。{userName}に気をかけてもらった多くの人が感謝しています。',
'{userName}のいいところは感受性です。{userName}が感じたことに皆が共感し、わかりあうことができます。',
'{userName}のいいところは節度です。強引すぎない{userName}の考えに皆が感謝しています。',
'{userName}のいいところは好奇心です。新しいことに向かっていく{userName}の心構えが多くの人に魅力的に映ります。',
'{userName}のいいところは気配りです。{userName}の配慮が多くの人を救っています。',
'{userName}のいいところはその全てです。ありのままの{userName}自身がいいところなのです。',
'{userName}のいいところは自制心です。やばいと思ったときにしっかりと衝動を抑えられる{userName}が皆から評価されています。',
'{userName}のいいところは優しさです。あなたの優しい雰囲気や立ち振る舞いに多くの人が癒やされています。'
];

// 名前の文字列を渡すと診断結果を返す関数
function assessment(userName) {
let sumOfCharCode = 0;
for (let i = 0; i < userName.length; i++) {
sumOfCharCode = sumOfCharCode + userName.charCodeAt(i);
}
const index = sumOfCharCode % answers.length;
let result = answers[index];
result = result.replace(/\{userName\}/g, userName);
return result;
}


// テストコード
console.assert(assessment('kensuke') === 'kensukeのいいところは用心深さです。kensukeの洞察に、多くの人が助けられます。', '診断結果が正しくない')
console.assert(assessment('kensuke') === assessment('kensuke'), '入力名が同じだが違う結果')