IEでもFirefoxでも動作する点滅文字について
Internet ExplorerでもFirefoxでも動作する点滅文字を作成するため、
下記のサンプルソースを作成したのですが、
Internet Explorer7では動作するものの、Firefox3.6では動作しませんでした。
その為、Internet ExplorerでもFirefoxでも動作する点滅文字の方法をご存知の方がいらっしゃいましたら、
ご教示の程、よろしくお願いします。
なお、下記の動作を想定しています。
1. 点滅時間は設定ファイルに記述して、点滅時間を調整したいと思います
(その為、<blink>タグは使用できないかも知れません)。
2. ページ内の複数の箇所に設定したいと思います
(ただし、設定箇所が何箇所になるかは、ページが動的に生成されているため、ランダムです。
その為、id属性で動作するものは使用できないかも知れません)。
3. MARQUEEタグを使用するものについては、位置あわせがうまく出来ませんでした。
【ソース】
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dt …
<html xmlns="http://www.w3.org/1999/xhtml" lang="ja" xml:lang="ja">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta http-equiv="Content-Style-Type" content="text/css" />
<meta http-equiv="Content-Script-Type" content="text/javascript" />
<title>title</title>
<script type="text/javascript">
<!--
function blink() {
if (!document.all) { return; }
for (i = 0; i < document.all.length; i++) {
obj = document.all(i);
if (obj.className == "blink") {
if (obj.style.visibility == "visible") {
obj.style.visibility = "hidden";
} else {
obj.style.visibility = "visible";
}
}
}
setTimeout("blink()", 800);
}
// -->
</script>
</head>
<body onload="blink()">
<h1 class="blink">点滅サンプル</h1>
<p>これは普通の文書</p>
<p class="blink">これは点滅する文章</p>
</body>
</html>
以上、よろしくお願いします。
No.3ベストアンサー
- 回答日時:
もくししてわかるなら、てきとうなぶひんもそろっていると・・
<!DOCTYPE html>
<title></title>
<body>
<h1>
<span class="a">点</span>
<span class="b">滅</span>
<span class="a">サ</span>
<span class="b">ン</span>
<span class="a">プ</span>
<span class="b">ル</span>
</h1>
<script type="text/javascript">
var Blinker = function ( viewTime, hiddenTime ) {
this.timerId = null;
this.buf = [ ];
this.viewTime = viewTime;
this.hiddenTime = hiddenTime;
this.mode = false;
this.start();
};
Blinker.prototype.view = function ( ) {
for( i = 0, I = this.buf.length; i < I; i++ )
this.buf[i].style.visibility = 'visible';
};
Blinker.prototype.hide = function ( ) {
for( i = 0, I = this.buf.length; i < I; i++ )
this.buf[i].style.visibility = 'hidden';
};
Blinker.prototype.start = function ( ) {
this.timerId && this.stop();
this.loop();
};
Blinker.prototype.loop = function ( ) {
this.mode ? this.view(): this.hide();
this.timerId = setTimeout( (function ( that ) {
return function ( ) { that.loop(); }; })( this ),
this.mode ? this.viewTime: this.hiddenTime );
this.mode = ! this.mode;
};
Blinker.prototype.stop = function ( ) {
this.timerId && clearInterval( this.timerId );
this.timerId = null;
};
Blinker.prototype.add = function ( n ) {
n && this.buf.push( n );
};
Blinker.create = function ( viewTime, hiddenTime ) {
var obj = new Blinker ( viewTime, hiddenTime || viewTime );
var arg = 2, id, n;
while( id = arguments[ arg++ ] ) {
n = document.getElementById( id );
n && obj.add( n );
}
return obj;
};
Blinker.createByClassName = function ( cssName, viewTime, hiddenTime ) {
var obj = new Blinker ( viewTime, hiddenTime || viewTime );
var allNode = document.getElementsByTagName( '*' );
var reg = new RegExp( '(?:^|\\s)' + cssName + '(?:$|\\s)' );
var cnt = 0, n;
while( n = allNode[ cnt++ ] )
if( n.className && reg.test( n.className ) )
obj.add( n );
return obj;
};
var str1 = Blinker.createByClassName( 'a', 400 );
var str2 = Blinker.createByClassName( 'b', 200 );
</script>
ご回答ありがとうございます。
ご教示いただいたソースを試してみたところ、
意図した動作をしている事を確認しました。
【index.html】
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dt …
<html xmlns="http://www.w3.org/1999/xhtml" lang="ja" xml:lang="ja">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta http-equiv="Content-Style-Type" content="text/css" />
<meta http-equiv="Content-Script-Type" content="text/javascript" />
<title>title</title>
</head>
<body>
<h1>
<span class="a">点</span>
<span class="b">滅</span>
<span class="a">サ</span>
<span class="b">ン</span>
<span class="a">プ</span>
<span class="b">ル</span>
</h1>
<p class="a">テスト1</p>
<p class="a">テスト2</p>
<p class="a">テスト3</p>
<script type="text/javascript" src="blink.js"></script>
</body>
</html>
【blink.js(ご教示いただいたjavascriptをそのまま貼り付けました。)】
var Blinker = function ( viewTime, hiddenTime ) {
略
var str2 = Blinker.createByClassName( 'b', 200 );
そのたびはどうもありがとうございました。
以上、よろしくお願いします。
No.2
- 回答日時:
こういうのは、どうかな?ばぶぅ~
ぜんかくくうはくもじは、はんかくにしてちょ!
<!DOCTYPE html>
<title></title>
<body>
<h1>
<span id="a0">点</span>
<span id="a1">滅</span>
<span id="a2">サ</span>
<span id="a3">ン</span>
<span id="a4">プ</span>
<span id="a5">ル</span>
</h1>
<p>これは普通の文書</p>
<p id="b0">これは点滅する文章</p>
<script type="text/javascript">
//@cc_on
var Blinker = function ( viewTime, hiddenTime ) {
this.timerId = null;
this.buf = [ ];
this.viewTime = viewTime;
this.hiddenTime = hiddenTime;
this.mode = false;
this.start();
};
Blinker.prototype.view = function ( ) {
for( i = 0, I = this.buf.length; i < I; i++ )
this.buf[i].style.visibility = 'visible';
};
Blinker.prototype.hide = function ( ) {
for( i = 0, I = this.buf.length; i < I; i++ )
this.buf[i].style.visibility = 'hidden';
};
Blinker.prototype.start = function ( ) {
this.timerId && this.stop();
this.loop();
};
Blinker.prototype.loop = function ( ) {
this.mode ? this.view(): this.hide();
this.timerId = setTimeout( (function ( that ) {
return function ( ) { that.loop(); }; })( this ),
this.mode ? this.viewTime: this.hiddenTime );
this.mode = ! this.mode;
};
Blinker.prototype.stop = function ( ) {
this.timerId && clearInterval( this.timerId );
this.timerId = null;
};
Blinker.prototype.add = function ( n ) {
n && this.buf.push( n );
};
Blinker.create = function ( viewTime, hiddenTime ) {
var obj = new Blinker ( viewTime, hiddenTime || viewTime );
var arg = 2, id, n;
while( id = arguments[ arg++ ] ) {
n = document.getElementById( id );
n && obj.add( n );
}
return obj;
};
//____________________
var str1 = Blinker.create( 200, 100, 'a0', 'a2', 'a4' );
var str2 = Blinker.create( 400, 200, 'a1', 'a3', 'a5' );
var str3 = Blinker.create( 1000, 500, 'b0' );
</script>
</body>
</html>
ご回答ありがとうございます。
ご教示いただいたソースを目視したところ、
想定動作の 2 が満たされていないようでした。
【1】
私の環境では、現状 id 名が固定になってしまう為です
(id を振る部分のプログラムを動的にして a + 連番 という形にできれば
使えるかも知れませんが)。
<span id="a0">点</span>
<span id="a0">滅</span>
<span id="a0">サ</span>
<span id="a0">ン</span>
<span id="a0">プ</span>
<span id="a0">ル</span>
【2】
下記のソースからは id の数が固定のような印象を受けました。
var str1 = Blinker.create( 200, 100, 'a0', 'a2', 'a4' );
var str2 = Blinker.create( 400, 200, 'a1', 'a3', 'a5' );
var str3 = Blinker.create( 1000, 500, 'b0' );
私の環境では、ページ毎に点滅する数が異なり、
数個の場合もあれば、数十個の場合もあり、
何個になるかはデータに依存しています。
以上、よろしくお願いします。
No.1
- 回答日時:
最初の document.all で思いっきり return しちゃってるのでは?
とりあえずの応急処置
function blink() {
//if (!document.all) { return; }
var all = document.getElementsByTagName('*');
for (i = 0; i < all.length; i++) {
obj = all[i];
---以下そのまま---
しかし、毎回全部の中から探すというのもねぇ…
ご回答ありがとうございます。
意図した動作をしている事を確認しました。
応急処置との事ですが、とりあえずご教示いただいたソースで進めていこうと思います。
どうもありがとうございました。
以上、よろしくお願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「nullまたはオブジェクトでは...
-
bt_melter.jsをサイトの一部の...
-
シンプルなweb版スタンプラリー...
-
google apps scriptの終了のさせ方
-
パス付きサイトのjavascript解析
-
Linux バイナリ実行できない "...
-
html javascript リンク先アド...
-
複数ファイルで使うグローバル...
-
functionから別のfunctionを実...
-
関数でy=g(x)のgとは何の略です...
-
テキストボックスに入力された...
-
class指定したHTML要素の背景色...
-
UWSCでオンクリックのボタンを...
-
リンク集をCSVファイルで管理し...
-
function(e)の意味を教えてくだ...
-
Boolean型配列中のTrueの有無を...
-
このプログラムに、王手をかけ...
-
jQuery 変数を複数のセレクタ...
-
Vb.netのグローバル変数の宣言...
-
マウスでポイントすると説明を表示
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
<a>タグのテキストを取得
-
ActiveXobjectが作成できない
-
onchangeイベントを使ってspan...
-
任意の座標をクリックさせるには
-
JavaScript を使ってpkゲームを...
-
javascript 特定のタグのidの存...
-
配列の大括弧と丸括弧はどう違う?
-
問題はbind の付いたリスナーを...
-
javascriptであるボタンを押す...
-
innerHTML実行後のイベント
-
RadioButtonListの表示制御
-
HTML:Tableタグに対し、JavaScr...
-
画像の一部を表示
-
appendChildがieだとできない??
-
div要素内の全input要素をdisable
-
クッキーを食べさせた会員には...
-
JavaScriptでオブジェクトを取...
-
javascriptでCSVを呼出しvlookup
-
画像上のクリックした場所が分...
-
画像をダブルクリックでスムー...
おすすめ情報