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

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

    JavaScript覧 / PC版 /
    スレッド評価: スレッド評価について
    みんなの評価 :
    タグ : 追加: タグについて ※前スレ・次スレは、スレ番号だけ登録。駄スレにはタグつけず、スレ評価を。荒らしタグにはタグで対抗せず、タグ減点を。
    ←前へ 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 次へ→ / 要望・削除依頼は掲示板へ / 管理情報はtwitter

    352 = :

    もしかしたらオブジェクト定義の中にthisを書いたらオブジェクトがthisになるのかと思って
    たしかめたけどやはりそんなことはありませんでした
    記述ミスですかね~

    353 = :

    winXPを久しぶりに起動したらwindows updateが来ていました
    またXPのサポートが終わった時から
    avg2014が使えなくなっていたのですが
    avg2015を入れたら問題なく使えるようになりました
    なんだかサポート期限なんてなかったみたいな雰囲気になってますが
    ということはIE6が延命していくのでしょうか?

    354 = :

    延命? 命を延ばすわけ無いだろ。
    余命過ぎてもまだ生きてるぐらいの意味だ。

    357 = :

    greasemonkeyスクリプトなんですが、
    スクロールを一定回数止めるため以下のように書きました。

    var count = 1;
    var scrollY;
    start();
    function start(){
    scrollY = document.body.scrollTop;
    window.addEventListener('scroll', scrollStop,false);
    }
    function scrollStop(){
    count++;
    window.scrollTo(0, scrollY);
    if(count > 20) window.removeEventListener('scroll', scrollStop,false);
    }

    firefoxでは正常に動くのにchromeだとremoveEventListenerがうまく動きません。
    chromeに対応させるにはどうしたらいいのでしょうか?

    359 = :

    結構メモリを食うjavaプログラムをjs(+HTML)に移植しています。
    メモリエラーが出る関係から、sshを使って他のスペックの高いマシンでjava実行を
    していたのですが、jsを同様にスペックの高いマシンの方で実行する方法はあるのでしょうか?
    Node.jsのサイトなどを見ていたのですがこれでいいのかよく分からず・・・。
    スレチ、文が意味不明、だったらごめんなさい

    360 = :

    >>359
    多分nodeでいいよ。

    hello.js というファイル名でconsole.log('hello') って書いて
    node hello.js とやるとちゃんとhelloって言ってくれる。

    ただ、ブラウザで動かしているものをnodeで動かすとしたら
    ちゃんとJavaScript(ECMAScript)の仕様の範囲にしておかないとダメだけどね。

    ブラウザで動かすJavaScriptは、純粋なJavaScriptではなくて
    DOMというブラウザ専用ライブラリが組み込まれた状態。

    だからDOMを使わないコードにしておかないといけない。・・・原則的には。

    NodeはNodeでその実行環境にはブラウザを超える能力があるから
    ライブラリ次第でDOMも使える。

    話がそれたけど、別のマシンで動かすならNodeでOK
    そのコードの書き方はDOMを使わないように気をつけることだね。

    361 = :

    >>360
    周りに聞ける人がいないので本当に助かります。
    DOMを使わず書けるならそれが望ましい(結果的に楽?)のですね
    とりあえずnodeで良さそうなので、もう少し書籍等調べてみます。
    ご丁寧にありがとうございました。

    362 = :

    >>356
    > ECMA Script 3 では、入れ子になった関数内で、thisを使うと、
    > グローバルオブジェクトを指すというバグがあったが、
    > ECMA Script 5 では、修正されるらしい
    初耳ですが、具体的にはどのようなコードでバグが再現されるのでしょう?
    ES3での該当箇所や参考URLがあれば、掲示していただけると助かります

    365 = :

    >>363
    具体的な2chのURLはどこになるでしょう?
    また、バグと判断できる根拠は?

    >>364
    ES3では this はグローバルオブジェクトを参照する仕様ですが、ES5 でも変わってはいません
    Strict Mode でのみ this は undefined を参照します
    このように理解しているのですが、>>356の勘違いのような気がしてきました

    366 = :

    >>357ですが自己解決しました
    あれこれ試した結果、案外単純にwindow.onscrollで一時停止と解除ができました。

    結局なぜremove出来なかったのかわからずじまいでしたがお騒がせしました

    368 :

    >>367
    ウインドウが違うのに要素って移動していいのかな?
    子ウインドウであればセキュリティ的には問題ないはずなんだけど
    仕様的にどうなんだろう。

    興味があるので詳しい人お願い

    369 = :

    配列a(a[3000][3000]くらい)の中身を関数(js)B,C,D・・・で書き換え操作するプログラムを作っています
    HTMLでファイルを読み込み、ロードが終わり次第、関数Bを呼び出し、Bが終わり次第
    B内でCを呼び出し・・・としています。

    これで上手くいけばいいのですが、メモリエラーになってしまいます。
    BやC内でもaと同サイズの配列を新たに生成しているためメモリを食うとは思うのですが
    やり方としておかしなところがあったりしますでしょうか?
    GCのために使わなくなった大きな配列データはnullで初期化してるつもりなのですが・・・

    370 = :

    >>369
    >GCのために使わなくなった

    それだとGCのタイミングに依存するかも
    js 側の処理を中断して一度制御をブラウザ側に返す必要があるかもしれない

    可能なら作業用の配列を何度も使い回す方がいいだろう

    371 = :

    >>370
    GCという機能があるというのは知っていましたが
    タイミングを含めて、どのように実行しているか調べていなかったので
    開発者ツール?でチェックしてみようかと思います。

    どちらかというと、未だによく理解できていないクロージャーの方が
    問題かと思っていたのですが、そうでもなかったのですかね。
    ご返答ありがとうございました。

    372 = :

    DTならよく知っています。

    373 = :

    >>369
    > GCのために使わなくなった大きな配列データはnullで初期化してるつもりなのですが・・・

    GCだと推測して対策ししたが効果はなかったということは、
    GCは関係ないってことだよ。

    374 = :

    >>369
    どうやってHTMLでファイル読み込んでるのかしらんけど、
    非同期処理の問題でしょ?

    375 = :

    >>372-374
    今確認したところ非同期処理でファイルを読み込んでいるみたいでした。
    同期処理のもあるみたいなのでそれで一度試してみます。
    ただ、非同期のために値が取れていないという訳ではないんですよね・・・。

    376 = :

    >>375
    原因追及のために同期処理でやってみるのもいいけど
    同期処理はあまりやらないほうがいいよ

    378 = :

    無限ループって怖いよね

    381 = :

    githubとかってjavascriptの勉強に使えますか?
    英語読めないし、使い方がさっぱり分かりませんでした。

    382 = :

    評価お願いします><


    無からギター音
    http://jsdo.it/jagarikin/t4Rm

    383 = :

    英語が分からなくても、JavaScriptという万国共通語があれば大丈夫

    384 = :

    perlワンライナーで語るみたいな

    385 :

    backbone.jsを勉強しています
    ビューの中でモデルにハンドラをセットし、モデルの変更をビューに反映させる、
    ということは分かりましたが、
    マウスなどの入力をモデルに反映させるのはどこでやるんですか?

    386 = :

    ボタンを押した時の処理をどこで受けるのか的なことです

    387 = :

    viewのeventsプロパティがハンドラとしてセットされ、
    viewのメソッドで受けるようです
    なんとなくコントローラの役割のような気がするのですが違うのでしょうか?

    388 = :

    >>381
    gitの本は、一杯あるよ

    日本のサイトでも、サイト内だけだけど、MITライセンスで、
    JSのソースコードを共有しているし、自由に使える。
    ゲームも一杯ある
    http://jsdo.it/

    389 = :

    >>387の件ですが、
    backboneのコントローラはURLとハッシュによって呼び出されるメソッドの集積のようですね
    サーバサイドのコントローラに近いですね

    391 = :

    開発者ツールでいいんじゃね

    393 = :

    昼休みは、会社の食堂でメシ食ってるときにテレビ見てるんだけどさ、
    今どきのjs(女子小学生)のファッション特集とかよくやってんだけど、
    マジでJS(女子小学生)って普通にテレビで言うようになったんだな。
    うかつに「休日はJS(Javascript)の勉強してます」っていうと
    「JS(女子小学生)の勉強・・通報しなきゃッ!」って感じで
    通報されかねないやん

    394 = :

    別に会話中にJavaScriptをJSなんて言わないよ

    395 = :

    「はじめてのC」

    396 = :

    Backbone.jsのViewで、classNameやidというプロパティは
    スカラー値にすることも関数にすることも出来、
    関数だった場合は返り値を設定したことになるそうですが
    これナイスな方法ですね?

    397 = :

    >>396
    はい。ナイスな方法でよく使われます。
    よく使われるので、汎用JavaScriptライブラリのlodashは
    まさにそのための関数_.resultを用意しています。

    http://lodash.com/docs#result

    var object = {
    'cheese': 'crumpets',
    'stuff': function() {
    return 'nonsense';
    }
    };

    _.result(object, 'cheese');
    // → 'crumpets'

    _.result(object, 'stuff');
    // → 'nonsense'

    398 = :

    ほお
    lodash使ってたのに知りませんでした
    ありがとうございます

    399 = :

    lodashはいい加減3.0をリリースして欲しい所。
    全体のどれくらい終わったんだろうか。

    400 = :

    qiitaに投稿した記事がやたらアクセス数が多い(3500超えた)と思ったら、
    「Javascript ~ ~」って検索すると一番上にqiitaに投稿した記事が来た
    ストック6しかないのにな、業務とかでググってる人が多いのだろうか?


    ←前へ 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 次へ→ / 要望・削除依頼は掲示板へ / 管理情報はtwitterで / JavaScript一覧へ
    スレッド評価: スレッド評価について
    みんなの評価 :
    タグ : 追加: タグについて ※前スレ・次スレは、スレ番号だけ登録。駄スレにはタグつけず、スレ評価を。荒らしタグにはタグで対抗せず、タグ減点を。

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


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