始めに読み込む画像を固定して、画像クリックで複数登録してある画像にランダムで切り替える方法
当方HTML+CSSは習得していますがJAVAの知識は殆どありません。
ページ内で画像を使った占いのようなコンテンツを作りたいのですが、画像ランダム切り替えのスクリプトにページをリロードしたときにしか表示されない扉画像を付けたいのと思っています。扉画像ををクリックすると「占い結果」画像が表示される、といった具合です。また、「占い結果」画像をさらにクリックすることでまた別画像に切り替えるようにしたいのですが、どなたか教えてください。
No.2
- 回答日時:
>また別画像に切り替える
の意味が良くわかりませんでした。
とりあえずクリックするとまた占うようにしましたが。
素人作なので参考程度です。
それでも意味が判るのにかなり時間はかかると思います。
リロード=window.onload
ランダム=Math.floor( Math.random() * Len );
(0以上Len未満の整数をランダムで返す。)
<style type="text/css">
<!--
body,dl,dd{ margin: 0px;padding: 0px; }
dl#x img{cursor:pointer;}
-->
</style>
<script type="text/javascript">
<!--
var ImgList = new Array(
["image01.jpg","画像01"],
["image02.jpg","画像02"],
["image03.jpg","画像03"],
["image04.jpg","画像04"],
["image05.jpg","画像05"]
);
var Len = ImgList.length;
var w = 300,h = 225;
var fortuneImg = new Array( Len );
/* 画像先読み */
function preLoad(){
for (var i = 0; i < Len; i++ ){
fortuneImg[i] = new Image();
fortuneImg[i].setAttribute('src', ImgList[i][0]);
fortuneImg[i].setAttribute('alt', ImgList[i][1]);
fortuneImg[i].setAttribute('width', w);
fortuneImg[i].setAttribute('height', h);
}
}
function showDoorImg(){
var dl = document.getElementById("x");
var dd = document.createElement('DD');
var img = document.createElement('IMG');
img.setAttribute('src',"image00.jpg");
img.setAttribute('alt',"扉画像");
img.setAttribute('width',w);
img.setAttribute('height',h);
if( navigator.userAgent.indexOf("MSIE") != -1 ) {
img.setAttribute( 'onclick', new Function( 'showResult(this)' ) );
}else{
img.setAttribute( 'onclick', 'showResult(this)');
}
dd.appendChild( img );
dl.appendChild( dd );
}
function showResult( t ){
var r = Math.floor( Math.random() * Len );
t.src = fortuneImg[r].src;
t.alt = fortuneImg[r].alt;
}
//-->
</script>
<script type="text/javascript">
<!--
window.onload = function(){
preLoad();
showDoorImg();
}
//-->
</script>
</head>
<body>
<dl id="x"><dt>画像をクリックすると占い結果が出ます。</dt></dl>
</body>
</html>
この回答への補足
回答ありがとうございます。
通常のHTMLページでは動作するのですが、ECショップ内のページにて使用するため、スクリプトを外部で読み込ませるようにしなければならないのです。
No.3ベストアンサー
- 回答日時:
サンプルです。
(画像切り替えにアニメーション効果付けてます。)HTML-ヘッダ内
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4. …
<script type="text/javascript" src="sample.js"></script>
HTML-BODY内(imgにidを付けておく)
<img src="扉絵のURI" id="fortune" alt="" width="~" height="~">
sample.js
$(function(){
var imglist = new Array(
'画像AのURI',
'画像BのURI',
~略~
'画像XのURI'
);
var fadeOutTime = 200; // 単位:ミリ秒
var fadeInTime = 600; // 単位:ミリ秒
for(var i=0;imglist[i];i++) $('<img src="'+imglist[i]+'">');
$('#fortune').click(function(){
var no = Math.floor( Math.random() * (imglist.length));
$(this).animate({opacity:0.1},fadeOutTime,function(){
$(this).attr('src',imglist[no])
.animate({opacity:1},fadeInTime);
});
});
});
回答ありがとうございます。
ページに組み込んだところ、しっかりと動作しました!
フェード効果も雰囲気に良い作用をしています。
改めてどうもありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
textareaに画像を表示したい
-
画像とコメントの同時表示をし...
-
画像の入れ替え
-
Nivo Sliderのエフェクトについて
-
jsプラグインの改造はできますか?
-
Photoswipeのアニメーションの変更
-
画像が表示でnull; this.src
-
VideoBoxのカスタマイズ
-
jQueryを使ってランダムに表示
-
「jQuery」アコーディオンメニ...
-
MAX関数を使ってからLEFT JOIN...
-
スクロール可能なチェックボックス
-
クリックすると下に説明文が出...
-
フッター上部に謎の隙間
-
htmlの記述で link rel=styles...
-
MFCで画像を表示させているので...
-
テーブル幅を自動で画像幅にし...
-
外部ファイルにしたら文字化け...
-
マウスオーバーで他の2個の画像...
-
jquery 3の倍数のliだけ色を変える
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
textareaに画像を表示したい
-
Gifアニメ、最後のコマに行った...
-
JavaScript スライドの画像にリ...
-
bxsliderにて読み込み後に内容...
-
透過pngの透明部分以外をクリッ...
-
JavaScriptとチェックボックス...
-
クリッカブルマップの一部分だ...
-
innerHTMLで、表示すると、一部...
-
Javascriptで指定した日付と時...
-
画像をフォルダに入れれば表示...
-
1枚の画像をクリックすると複数...
-
WEBページ立ち上げ時に1回のみ...
-
image.onload = .. の後に imag...
-
美人時計風JAVAスクリプトが上...
-
曜日と時間を指定して表示画像...
-
決まった曜日で一定時間だけ表...
-
画面の表示位置を指定させて表...
-
jQuery FlexSliderのカルーセ...
-
特定の画像を非表示にする方法
-
iframe内のリンク文字のマウス...
おすすめ情報