回答編集履歴

1

edit

2021/02/09 09:42

投稿

m.ts10806
m.ts10806

スコア80875

test CHANGED
@@ -25,3 +25,141 @@
25
25
 
26
26
 
27
27
  あとは適宜ドキュメントを参照。
28
+
29
+
30
+
31
+ ---
32
+
33
+
34
+
35
+ 「やりたいこと」を元に「どれが関数でどれが引数でどこが文末か」を意識できていれば、
36
+
37
+ 今回のようなミスは防ぐことができます。
38
+
39
+ 「上から順番に書く」のではなく「機能まとまりから書く」ことを意識。
40
+
41
+ つまり、「どこに関数を置いてその関数の何番目にどんな引数を置くか」をきちんと分解して考えられるようになる必要があります。
42
+
43
+
44
+
45
+ jQueryの基本系は「セレクタ」に対して「何かしらイベントや処理を呼び出す」です。
46
+
47
+ 関数の呼び出しは 関数名()とう原則から
48
+
49
+ `$()`自体が関数であることになります。`$()`は`jQuery()`のエイリアス(別名、短縮形)。
50
+
51
+
52
+
53
+ あとはこの関数に引数を与えていくことで動作するわけです。
54
+
55
+
56
+
57
+ 基本系を書く
58
+
59
+ ```js
60
+
61
+ $()
62
+
63
+ ```
64
+
65
+ 呼び出したいセレクタ
66
+
67
+ ```js
68
+
69
+ $("#button")
70
+
71
+ ```
72
+
73
+ それに対する関数(関数の呼び出し結果に対して関数を呼び出す方式がとられています)
74
+
75
+ ```js
76
+
77
+ $("#button").on();
78
+
79
+ ```
80
+
81
+ 文末なので;もつけておく
82
+
83
+
84
+
85
+ [on()](https://api.jquery.com/on/)関数の機能を確認
86
+
87
+ 引数1つ目はイベント
88
+
89
+ ```js
90
+
91
+ $("#button").on('click');
92
+
93
+ ```
94
+
95
+
96
+
97
+ 今回は間のselectorやdataはないので、引数2つ目はhandler(function)
98
+
99
+ ```js
100
+
101
+ $("#button").on('click',function(){});
102
+
103
+ ```
104
+
105
+ 読みやすいように改行
106
+
107
+ ```js
108
+
109
+ $("#button").on('click',function(){
110
+
111
+
112
+
113
+ });
114
+
115
+ ```
116
+
117
+
118
+
119
+ あとはhandler内に処理を書いていく
120
+
121
+ ```js
122
+
123
+ $("#button").on('click',function(){
124
+
125
+ var atai = $("input[type=text]").value();
126
+
127
+ alert("atai");
128
+
129
+ });
130
+
131
+ ```
132
+
133
+
134
+
135
+ 私も以前は下記を毎回どこかに控えておいてコピペしてましたが、
136
+
137
+ ```js
138
+
139
+ $(function(){
140
+
141
+ });
142
+
143
+ ```
144
+
145
+ 「機能で分解して理解する」ことを意識しだしてからは見なくても書けるようになりました(あとはやはりドキュメントのおかげか)
146
+
147
+
148
+
149
+ なので、「分解」という観点から、変数を利用してこんな感じにも書けることが分かると思います(未検証)
150
+
151
+ ```js
152
+
153
+ let btn = $("#button");
154
+
155
+ let clickFunc = function(){
156
+
157
+ var atai = $("input[type=text]").value();
158
+
159
+ alert("atai");
160
+
161
+ }
162
+
163
+ btn.on('click',clickFunc);
164
+
165
+ ```