質問編集履歴

2

ソースコードを追加しました

2022/11/15 07:27

投稿

kinoko_0129
kinoko_0129

スコア6

test CHANGED
File without changes
test CHANGED
@@ -3,6 +3,83 @@
3
3
  checkボタンを押すと、並び替えたプログラムが配列として保存されます。そこで、配列をプログラムテストサイトに移動し、実行結果だけをHTML内に表示したいと考えています。何か参考になるような記事やアドバイス等がございましたら回答お願いいたします。
4
4
 
5
5
 
6
+ ### ソースコード
7
+ ```HTML
8
+ <!DOCTYPE html>
9
+ <html lang="ja">
10
+ <head>
11
+ <meta charset="utf-8">
12
+ <title>短冊プログラム</title>
13
+ <!-- スタイルシート(外部CSSファイル)を読み込む -->
14
+ <link rel="stylesheet" href="style.css">
15
+ </head>
16
+
17
+
18
+ <body>
19
+
20
+ <h2>プログラムを正しい順番に並べ替えてください</h2>
21
+
22
+ <!-- 並び替えるリスト -->
23
+ <div class="list" id="list1">
24
+ <div class="list-item">printf("Hello,World\n");</div>
25
+ <div class="list-item">{</div>
26
+ <div class="list-item">main()</div>
27
+ <div class="list-item">}</div>
28
+ </div>
29
+
30
+ <!-- 並び替えライブラリ読み込み・生成 -->
31
+ <script src="Sortable.min.js"></script>
32
+ <script>
33
+ var el = document.getElementById('list1');
34
+ var sortable = new Sortable(el, {
35
+ animation: 150,
36
+ ghostClass: "ghost"
37
+ });
38
+
39
+ // 正誤判定プログラム
40
+ function check() {
41
+
42
+ //挿入用の空配列
43
+ let answer = [];
44
+
45
+ //正しい順番の配列(正誤判定用)
46
+ var correctAnswer = ["main()","{","printf(\"Hello,World\\n\");","}"];
47
+
48
+ // list-itemクラスの要素の集合を取得
49
+ var listItems = document.getElementsByClassName("list-item");
50
+
51
+ //並び替えた配列の要素を空の配列に挿入
52
+ for(let i = 0; i < listItems.length; i++){
53
+ answer.push(listItems[i].innerText);
54
+ }
55
+
56
+ console.log(correctAnswer);
57
+ console.log(answer);
58
+
59
+ //並び替えた配列(inputArr)と正しい順番の配列(arrayCorrect)を比較し正誤判定
60
+ if (answer.toString() === correctAnswer.toString()) {
61
+ document.getElementById("result").textContent = "正解!";
62
+ }else{
63
+ document.getElementById("result").textContent = "不正解!";
64
+ }
65
+
66
+ }
67
+
68
+ </script>
69
+
70
+
71
+ <!-- 正誤判定ボタン -->
72
+ <br />
73
+ <div align="center">
74
+ <button class="button1" onclick="check()">check</button>
75
+ </div>
76
+
77
+ <br />
78
+ <h4><span id="result"></span></h4>
79
+
80
+ </body>
81
+ </html>
82
+ ```
6
83
 
7
84
 
8
85
  ### 実現したいこと

1

フロー図、実行結果、ログを記載しました

2022/11/14 13:26

投稿

kinoko_0129
kinoko_0129

スコア6

test CHANGED
File without changes
test CHANGED
@@ -1,6 +1,6 @@
1
1
  ### 前提
2
2
  HTMLとJavascriptでプログラムを並び替えて正誤判定を行うような学習用のシステムを作っています。
3
- 回答ボタンを押すと、並び替えたプログラムが配列として保存されます。そこで、配列をプログラムテストサイトに移動し、実行結果だけをHTML内に表示したいと考えています。何か参考になるような記事やアドバイス等がございましたら回答お願いいたします。
3
+ checkボタンを押すと、並び替えたプログラムが配列として保存されます。そこで、配列をプログラムテストサイトに移動し、実行結果だけをHTML内に表示したいと考えています。何か参考になるような記事やアドバイス等がございましたら回答お願いいたします。
4
4
 
5
5
 
6
6
 
@@ -8,4 +8,11 @@
8
8
  ### 実現したいこと
9
9
  配列を外部サイト(プログラムテストサイト)に移動させ実行し、出力結果のみを自HTML内に表示させたい
10
10
 
11
+ ![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2022-11-14/35da8b1f-1a37-44ee-b8eb-3acaa251e694.png)
11
12
 
13
+ ### 実行結果
14
+ ![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2022-11-14/c0450b36-726b-4dd8-8cf2-c46f8262299f.png)
15
+
16
+ ![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2022-11-14/b6009bac-4ee1-4b92-8c6d-3c4671e684b4.png)
17
+
18
+