質問編集履歴
3
説明文の追加
test
CHANGED
File without changes
|
test
CHANGED
@@ -119,3 +119,119 @@
|
|
119
119
|
});
|
120
120
|
|
121
121
|
```
|
122
|
+
|
123
|
+
|
124
|
+
|
125
|
+
下記のコードの通り条件分岐を追加したらリサイズはうまくいくようになったのですが、画面幅を変えた時にしかスクリプトが動かずにいます。
|
126
|
+
|
127
|
+
load resizeをつけているのですがどこが間違っているのかわからずにいます。
|
128
|
+
|
129
|
+
|
130
|
+
|
131
|
+
|
132
|
+
|
133
|
+
```javascript
|
134
|
+
|
135
|
+
jQuery(function ($) {
|
136
|
+
|
137
|
+
$(window).on('load resize', function(){
|
138
|
+
|
139
|
+
|
140
|
+
|
141
|
+
var $windowWidth = window.innerWidth
|
142
|
+
|
143
|
+
var $breakPointA = 560; //画像を差し替えを実行するウィンドウサイズ
|
144
|
+
|
145
|
+
var $breakPointB = 959;
|
146
|
+
|
147
|
+
var isMobileSize = ($windowWidth < $breakPointA);
|
148
|
+
|
149
|
+
var isTabletSize = ($windowWidth <= $breakPointB) && ($windowWidth > $breakPointA);
|
150
|
+
|
151
|
+
var isPcSize = ($windowWidth > $breakPointB);
|
152
|
+
|
153
|
+
|
154
|
+
|
155
|
+
if (isTabletSize) {
|
156
|
+
|
157
|
+
|
158
|
+
|
159
|
+
var before = 'pc_',
|
160
|
+
|
161
|
+
before2 = 'mb_',
|
162
|
+
|
163
|
+
after = 'tb_';
|
164
|
+
|
165
|
+
|
166
|
+
|
167
|
+
replaceImg();
|
168
|
+
|
169
|
+
|
170
|
+
|
171
|
+
} else if (isMobileSize) {
|
172
|
+
|
173
|
+
|
174
|
+
|
175
|
+
var before = 'tb_',
|
176
|
+
|
177
|
+
before2 = 'tb_',
|
178
|
+
|
179
|
+
after = 'mb_';
|
180
|
+
|
181
|
+
|
182
|
+
|
183
|
+
replaceImg();
|
184
|
+
|
185
|
+
|
186
|
+
|
187
|
+
} else if (isPcSize) {
|
188
|
+
|
189
|
+
|
190
|
+
|
191
|
+
var before = 'tb_',
|
192
|
+
|
193
|
+
before2 = 'mb_',
|
194
|
+
|
195
|
+
after = 'pc_';
|
196
|
+
|
197
|
+
|
198
|
+
|
199
|
+
replaceImg();
|
200
|
+
|
201
|
+
|
202
|
+
|
203
|
+
}
|
204
|
+
|
205
|
+
|
206
|
+
|
207
|
+
function replaceImg(){
|
208
|
+
|
209
|
+
$('.tb[src*=pc_],.tb[src*=tb_],.tb[src*=mb_]').each(function(){
|
210
|
+
|
211
|
+
var img = $(this).attr('src').replace(before, after);
|
212
|
+
|
213
|
+
var img2 = $(this).attr('src').replace(before2, after);
|
214
|
+
|
215
|
+
if( $(this).attr('src').match(before) ) {
|
216
|
+
|
217
|
+
$(this).attr('src', img);
|
218
|
+
|
219
|
+
}
|
220
|
+
|
221
|
+
else if( $(this).attr('src').match(before2) ) {
|
222
|
+
|
223
|
+
$(this).attr('src', img2);
|
224
|
+
|
225
|
+
}
|
226
|
+
|
227
|
+
});
|
228
|
+
|
229
|
+
}
|
230
|
+
|
231
|
+
|
232
|
+
|
233
|
+
})
|
234
|
+
|
235
|
+
});
|
236
|
+
|
237
|
+
```
|
2
説明文追加
test
CHANGED
File without changes
|
test
CHANGED
@@ -9,6 +9,8 @@
|
|
9
9
|
スクリプトもあまり詳しくないためどこを書き換えていいかがわからずにいます。
|
10
10
|
|
11
11
|
スマホではファイルの先頭をmb_、タブレットではtb_、パソコンではpc_に変えてレスポンシブで画像を変更できるような動きをするためにはどのようにすれば良いのでしょうか?
|
12
|
+
|
13
|
+
現状の動きですと、pcからtb_、mb_までのブラウザサイズ変更でそぞれ画像が切り替わるのですが、ブラウザサイズを戻した際に画像の切り替えができずどのサイズでもmb_のままになってしまいます。
|
12
14
|
|
13
15
|
|
14
16
|
|
1
説明文変更
test
CHANGED
File without changes
|
test
CHANGED
@@ -9,10 +9,6 @@
|
|
9
9
|
スクリプトもあまり詳しくないためどこを書き換えていいかがわからずにいます。
|
10
10
|
|
11
11
|
スマホではファイルの先頭をmb_、タブレットではtb_、パソコンではpc_に変えてレスポンシブで画像を変更できるような動きをするためにはどのようにすれば良いのでしょうか?
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
現状の動きはブラウザ幅をpcからスマホサイズまで縮めるとファイルが変化するのですが、ブラウザ幅を元に戻すとモバイルサイズのmb_のまま可変しなくなってしまいます。
|
16
12
|
|
17
13
|
|
18
14
|
|