のくす牧場
コンテンツ
牧場内検索
カウンタ
総計:127,469,301人
昨日:no data人
今日:
最近の注目
人気の最安値情報

私的良スレ書庫

不明な単語は2ch用語を / 要望・削除依頼は掲示板へ。不適切な画像報告もこちらへどうぞ。 / 管理情報はtwitter
ログインするとレス評価できます。 登録ユーザには一部の画像が表示されますので、問題のある画像や記述を含むレスに「禁」ボタンを押してください。

元スレ+ JavaScript の質問用スレッド vol.77 +

JavaScript スレッド一覧へ / JavaScript とは? / 携帯版 / dat(gz)で取得 / トップメニュー
スレッド評価: スレッド評価について
みんなの評価 :
タグ : 追加: タグについて ※前スレ・次スレは、スレ番号だけ登録。駄スレにはタグつけず、スレ評価を。荒らしタグにはタグで対抗せず、タグ減点を。
レスフィルター : (試験中)
←前へ 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 次へ→ / 要望・削除依頼は掲示板へ / 管理情報はtwitter
651 : Name_Not - 2010/04/14(水) 15:14:26 ID:??? (+3,-30,-160)
onError が発生する前にalert( str )まで行ってるんじゃね?
↓実行するとfinish onloadから表示された

<script type="text/javascript">
window.onload = function (){
var str = "";
var imgAry = document.images;
for(var i=0; i<imgAry.length; i++){
var img = new Image();
img.onerror = function(){
str += img.src + "\n";
alert( "from onerror\n" + str );
}
img.src = imgAry[i].src;
}
alert( "finish onload\n" + str);
}
</script>
652 : 643です。 - 2010/04/14(水) 18:14:34 ID:??? (+3,-30,-158)
みなさん、いろいろ試していただきありがとうございます。

  var str = "";
  var imgAry = document.images;
  for(var i=0; i<imgAry.length; i++){
    var img = new Image();
    img.onerror = function(){
      str += this.src + "\n";
      console.log("途中\n" + str);
    }
    img.src = imgAry[i].src;
  }
  alert("結果\n" + str);
  console.log("結果\n" + str);

ってやると、アラートではstrが空ですが、コンソール上では以下のような順番で出力
され、結果のstrも期待通りの出力になっていました。
アラート無しでうまくいくようにするためにはonerrorが発生するまで待つような処理にする必要がありそうですが可能でしょうか?

途中
-----------------------------------
途中
-----------------------------------
結果
-----------------------------------
653 : Name_Not - 2010/04/14(水) 19:51:05 ID:??? (+24,+1,-16)
まずメモリーリークを直せ
656 : Name_Not - 2010/04/15(木) 03:43:33 ID:??? (+32,+14,+0)
宣伝乙
657 : Name_Not - 2010/04/15(木) 06:42:02 ID:??? (+48,-30,+0)
どうしてもボタン「すべて選択」が効かない。 教えてください。お願いします。function select()にイベントが届いていないようです。
0<body>
1<div id="imgCheck"></div>
2<script type="text/javascript">
3//@cc_on
4Number.prototype.zero = function(n){ return ('0000000000'+ this).slice(-n); }
5var html = '<form><input type="button" value="すべて選択" click="select(1)"><input type="button" value="すべて解除" onClick="select(0)">';
6for(i=0;i<10;i++){
7var src = 'img'+(i.zero(4))+'jpg';
8html += '<div class="imgbox"><img src="' + src + '.jpg" alt="'+src+'"><div><input type="checkbox" value="'+src+'">'+src+'</div></div>';
9}
10html += '</form>';
11document.getElementById('imgCheck').innerHTML = html;
12document.getElementById('imgCheck')./*@if(1)attachEvent('on'+ @else@*/addEventListener(/*@end@*/'mouseover', chk, false);
13function chk( evt ){
14var node = evt.target || evt.srcElement;
15if( node.nodeName == 'INPUT' && node.type =='checkbox' ) node.checked = !node.checked;
16}
17function select ( bool){
18 var x=document.getElementsByTagName('INPUT');
19
20 for (var i=0;x[i];i++){
21
22 if(!(x[i].type.match('checkbox')) )continue;
23
24 switch(bool){
25 case 1: x[i].checked = true; break;
26 case 0: x[i].checked = false; break;
27 }
28 }
29}
30</script>
658 : Name_Not - 2010/04/15(木) 07:15:35 ID:??? (+57,+29,-7)
>イベントが届いていないようです
だろうな。HTMLすらまともに書けてないもの。
659 : Name_Not - 2010/04/15(木) 09:45:47 ID:??? (+57,+29,-13)
イベントが届いてないなら届くように書けば良いじゃん
いちおうこれヒントな
660 : Name_Not - 2010/04/15(木) 10:59:26 ID:??? (+21,-6,-67)
スレ違いかもしれないんだが、選んだ項目(プルダウンメニュー)によって
自動返信の内容を変えるフリーのメールソフトってないですかね?
PHP、CGIどちらでもかまいません。
661 : Name_Not - 2010/04/15(木) 11:06:01 ID:??? (+39,-30,-100)
>>657
onclick="alert(select)"

スコープ順位の高い位置で select が定義されてる。
他に focus, click なんてのもある。

<input type="checkbox" onmouseover="focus(); click();">

名付けには気を遣え。
662 : Name_Not - 2010/04/15(木) 11:17:47 ID:??? (+35,-30,+0)
>>657
<html><head></head><body>
<form><input type="button" value="すべて選択" onclick="sel(1);" /><input type="button" value="すべて解除" onclick="sel(0);" /><div id="imgCheck"></div></form>
<script type="text/javascript">
Number.prototype.zero = function(n) { return ('0000000000' + this).slice(-n); };
var addEvent = function(node, type, fn) {
  if (document.addEventListener) node.addEventListener(type, fn, false);
  else if (document.attachEvent) node.attachEvent('on' + type, function(e) { fn.call(node, e); });
}, sel = function(num) {
  var nodes = document.getElementById('imgCheck').getElementsByTagName('input');
  for (var i = 0; nodes[i]; i++) (function(node) {
    if (num == 0) node.checked = false;
    else node.checked = true;
  })(nodes[i]);
}, html = '';
for (var i = 0; i < 10; i++) {
  var src = 'img' + i.zero(4) + 'jpg';
  html += '<div class="imgbox"><img src="' + src + '.jpg" alt="' + src + '" /><div><input type="checkbox" value="' + src + '">' + src +'</div></div>';
}
document.getElementById('imgCheck').innerHTML = html;
addEvent(document.getElementById('imgCheck'), 'mouseover', function(e) {
  var t = e.target || e.srcElement;
  if (t.nodeName == 'INPUT' && t.type =='checkbox') t.checked = !t.checked;
});
</script>
</body></html>
663 : Name_Not - 2010/04/15(木) 11:33:16 ID:??? (+62,+29,+0)
>>661,662

ありがとうございます。


がんばって今からやってみます。
664 : Name_Not - 2010/04/15(木) 11:36:34 ID:??? (+52,+29,-16)
何かもういろいろひでえな
665 : Name_Not - 2010/04/15(木) 12:03:07 ID:??? (+56,+29,+0)
>>662
えー……
666 : 657 - 2010/04/16(金) 23:39:44 ID:??? (+8,-30,-118)
>>661,662


なんとかがんばって理解しようとしてみた



・onclick」はonClick」でなくてもOKなんですね
・function(e)がよくわからない
 こうかいておけば、あらゆるイベントが起こった際に、これが呼び出される?
 eにはイベントオブジェクトが入る?
・元スクリプト>>657は、なぜ機能しなかったのか

・661さんの
 スコープ順位の高い位置で select が定義されてる。」

selectの書いた場所がどうならよかったのか
スコープ順位」とは?


ここらへんが謎です

667 : Name_Not - 2010/04/17(土) 00:45:51 ID:??? (+42,-30,-212)
HTMLであれば属性名の大文字小文字は区別されない

> >>657は、なぜ機能しなかったのか
5行目「click」じゃなくて「onclick」だろう

・イベント属性(onclick)の中でコンテキスト(this)はその要素
・input要素はselectメソッドを持つ
<input ~ onclick="select(1)">だとinput要素のselectメソッドが呼ばれる
=> onclick="window.select(1)"
=> 関数名を変える

662もそうだが、そのままbool使えばいいだろう。1はtrue、0はfalseだ
というか最初からonclick="select(true)"にしとけばいい
669 : Name_Not - 2010/04/17(土) 01:25:13 ID:??? (+57,+29,-16)
それはサイト側でやることなのか?
それと、もしそれでオフになったとしてもJSでやる必要なくね?
670 : Name_Not - 2010/04/17(土) 01:35:46 ID:??? (-14,-29,-29)
>>668
特定サイトだけではなく機能自体をOFFにしたいのなら、
以下の手順で切り替え可能

ツール>設定>詳細設定>閲覧>スペルチェック
671 : Name_Not - 2010/04/17(土) 02:03:28 ID:np2HCHTk (-16,+29,-28)
>>670
レスどうもです。

自分の作ったHTML上で使えるツールを使う時だけOFFにしたかったのですが、
使う人に対して「どうしても気になるならこういう風に設定して」と説明文を書いておくしか無いですかね。
672 : Name_Not - 2010/04/17(土) 04:32:17 ID:??? (+62,+29,-91)
正直、ただのお節介だと思う。
スペルチェックが必要ない人は最初から切ってる。
textareaを使ったサイトは2chを含め無数にあるのに、
あなたのサイトを訪れたときにだけスペルチェックの赤線が気になって
イライラするOperaユーザーなんて全世界に数人もいない。
逆に、それ以外の全ての人にとっては無駄な記述になる。
サイト側で気にすることじゃないよ。
674 : Name_Not - 2010/04/17(土) 10:36:22 ID:V4JRvi1z (+0,+1,-8)
現在フォーカス持ってる要素って取得できますか?
675 : Name_Not - 2010/04/17(土) 10:42:57 ID:??? (+25,-29,+0)
>>674
document.activeElement
676 : Name_Not - 2010/04/17(土) 11:27:16 ID:??? (+48,+22,+1)
>>675
ありがとう。
677 : 657 - 2010/04/17(土) 23:12:15 ID:??? (+63,+29,+0)
>>667

御礼遅れました。
ありがとう。
678 : Name_Not - 2010/04/18(日) 00:36:41 ID:??? (-3,-26,-82)
質問

なんでhtml内のうめこみスクリプトってjavascriptのみなの?
pythonとかjavaとかの文法がつかえれば便利だと思うんだけど
javascriptだけはなぜか不動の位置にあるのな。
たしかに、RailsとかPHPとかでjavascriptを動的に生成すればいいんだけど
それならRubyとかPHPの文法でいいじゃん、なんでjavascriptっていう違う言語に変換してるのか
よくわからん。
679 : Name_Not - 2010/04/18(日) 01:02:23 ID:??? (+94,+29,-53)
ブラウザの歴史的ないきさつもあるし、実行環境で用意されてる関数がWeb向きということもあるし、
文法的なことを言えばプロトタイプベースの言語だからページ構造の変化に強く自由度が高くて便利。
680 : Name_Not - 2010/04/18(日) 01:05:55 ID:??? (+75,+29,-69)
>>679
> 文法的なことを言えばプロトタイプベースの言語だからページ構造の変化に強く自由度が高くて便利。
他の言語つかったことないな?それとも信者?
そうじゃないというなら他の言語との比較をしてみてよ。C#やRubyやLispに比べて具体的にどのへんが自由度が高くてページ構造の変化に強いのか。
681 : Name_Not - 2010/04/18(日) 01:08:20 ID:??? (+94,+29,-69)
Lispは使ったことないが、C#, Rubyは経験あるな。
まずプロトタイプベースの利点を理解した上で文句をつけてるのか、
理解せずにただ持ち上げてるというだけで信者扱いしてるのか白状しる。
682 : Name_Not - 2010/04/18(日) 01:13:33 ID:??? (+96,+29,-59)
>>681
しらねーよwwそんなの。理解してません。てか、そんなの知らなくてもそれなりのシステムは組めてるからな。
たぶん説明されれば、わかるけど。

さあ、白状してやったから、
C#やRubyやLispに比べて具体的にどのへんが自由度が高くてページ構造の変化に強いのかいってみなさい。
683 : Name_Not - 2010/04/18(日) 01:27:04 ID:??? (+52,+29,-1)
自由度が高すぎると困る
終わり
684 : Name_Not - 2010/04/18(日) 01:38:30 ID:??? (-6,-29,-1)
VBScript「呼んだ?」
685 : Name_Not - 2010/04/18(日) 01:39:59 ID:??? (+91,+29,-15)
なんでHTTPでなんでHTMLでなんでFlashなのかって言われても返答に困るようなもんだよなぁ
デファクトスタンダードって強いよね
686 : Name_Not - 2010/04/18(日) 01:40:09 ID:??? (+44,+12,-61)
>>678
何かのフォームをイベント処理できるソフトを既存のRubyやPHPで書ける?
セキュアを完全保証できるという前提で
687 : Name_Not - 2010/04/18(日) 01:50:28 ID:??? (+70,+29,-17)
>>685でFAだなあ。
あと文法と実行方式とを混同してるアホはちょっと頭冷やした方がいいと思うよ。
サンドボックスって言葉ぐらい知っててもいいと思う。
688 : Name_Not - 2010/04/18(日) 01:51:23 ID:??? (+57,+29,-11)
言語仕様とオブジェクトライブラリは分けて語った方がいいぞ
689 : Name_Not - 2010/04/18(日) 01:57:33 ID:??? (-1,-29,-14)
IEならレジストリいじって好きなエンジン呼べるはず
ActivePerl入れればtext/perlscript使えるんじゃなかったっけ
691 : Name_Not - 2010/04/18(日) 03:25:34 ID:??? (+48,+30,+0)
692 : Name_Not - 2010/04/18(日) 10:22:02 ID:??? (+78,+4,-13)
>>682
>たぶん説明されれば、わかるけど。
ダウト。
693 : Name_Not - 2010/04/18(日) 12:37:56 ID:??? (+102,+29,-13)
>>692
言語そのものに対する盲目的な信仰を告白するのは
よっぽどの人が言うんでもなけりゃ痛いだけだからやめとけ
694 : Name_Not - 2010/04/18(日) 14:16:33 ID:??? (+57,+29,-40)
言語を単純な優劣でしか考えられない人がいるけどスルーで
Webクライアントに向いてるかという話題なのに
695 : Name_Not - 2010/04/18(日) 17:30:21 ID:??? (+71,+29,-11)
>>693
信仰?
説明されても判らない程に頭が悪そうだ、って話だ。
言わせんな恥ずかしい。
696 : Name_Not - 2010/04/18(日) 18:04:55 ID:??? (-1,-29,-2)
VBScript を盛り上げて行こうz
697 : Name_Not - 2010/04/18(日) 19:54:59 ID:??? (+32,+14,+1)
お断りします
698 : Name_Not - 2010/04/18(日) 20:52:09 ID:??? (+57,+29,-6)
C 系の言語ばかり使っていたら、考え方が偏っちゃうyo!
699 : Name_Not - 2010/04/19(月) 01:42:03 ID:??? (+2,-25,+0)
真理に近づきたくばschemeをやるべし
700 : Name_Not - 2010/04/19(月) 01:52:49 ID:??? (+52,+29,-1)
>真理に近づきたくば
いや別に
←前へ 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 次へ→ / 要望・削除依頼は掲示板へ / 管理情報はtwitterで / JavaScript スレッド一覧へ
スレッド評価: スレッド評価について
みんなの評価 :
タグ : 追加: タグについて ※前スレ・次スレは、スレ番号だけ登録。駄スレにはタグつけず、スレ評価を。荒らしタグにはタグで対抗せず、タグ減点を。

類似してるかもしれないスレッド


トップメニューへ / →のくす牧場書庫について