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

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

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

451 = :

http://sdsoffice.com/tools/homepage-patrol-v2b.html
上記サイトのwebサイトを巡回してくれるJavaScriptを利用をしようと思います。

windows8.1(64bit) + IE11の環境で、上記サイト上で実行させるには問題ないのですが、
htmlファイルとしてローカルに保存して、ローカルで実行するとエラーとなります。
(巡回してくれない)

windows7(64bit) + IE11の環境でしたら、ローカルでも問題なく動きます。

windows8.1でエラーになる原因がわかりません。
お詳しい方、力になっていただけないでしょうか?
よろしくお願いいたします。

452 :

別フレームに指定の複数のページをランダム時間(何分から何分の間ランダム)で表示する。

の参考資料とかありませんか?
十数年前「html」だったのか「javascript」か覚えていないけど
色んな例を組み合わせて作って偶然動いたことがあったのでどこかに保存しておいたんだけどなくなってしまったので・・・
よかったら教えてください。

453 = :

>>451
そもそも普通は、crossOrigin (CORS)アクセス禁止だろ

自分のPC 上の、HTML ファイルから、他のドメインにアクセスできないだろ。
iframe 内に、他のドメインのページを読み込んでも、
iframeの内外で、異なるサイトになるから、アクセスできない

自分のPC で、サーバーを立てて、それを経由しないとアクセスできない。
または、ネット上のそういうサーバーを利用するとか

以前使えていた、Yahoo Query Language (YQL) も、使えなくなった

454 = :

aからbまでの間でランダムは
a+(0からb-a)までランダムと表せられる
つまりa+Math.random()*(b-a)となる

456 = :

あるある質問かもしれませんが
Javascriptのソースコードからコメントをすべて除去するツールなり方法ってどんなものがあるでしょうか?
単独のフリーソフトでも良いですし
atomのbeautify等、構文解析するプラグイン等にオマケでついていてもおかしくないと思うのですが
windows7を使っています

458 = :

>>452
「jquery plugin カルーセル」で検索!

jQuery Plugin を探す方が、簡単かも

459 = :

>>456
「javascript コメント 削除 ツール」で検索!

461 = :

>>452
454 を修正した。
ランダム時間は難しくてできない。一定時間ならできる

以下を、<body>タグの中に書いて実行すれば、5秒毎に、違うサイトが読み込まれる。
タイマーを止めるには、clearInterval を使う

<iframe src="#" id="ifrm"></iframe>

<script type="text/javascript">
window.onload = function(){

var urls = ['http://www.example.com', 'http://www.yahoo.co.jp', 'http://www.google.co.jp'];

var ifrm = document.getElementById('ifrm');

var timerID = setInterval(function () {
// 0以上、3未満。つまり、0~2
var idx = Math.floor( Math.random() * urls.length );
ifrm.src = urls[idx];
}, 5000); // 5分なら、5 * 60 * 1000 とする
}
</script>

462 = :

458 を修正した

setTimeout() で、最初から表示する。
その後、setInterval() で、一定時間ごとに表示する

<iframe src="#" id="ifrm"></iframe>

<script type="text/javascript">
window.onload = function(){

var urls = ['http://www.example.com', 'http://www.yahoo.co.jp', 'http://www.google.co.jp'];

var ifrm = document.getElementById('ifrm');

function setExternalWebsite() {
// 0以上、3未満。つまり、0~2
var idx = Math.floor( Math.random() * urls.length );
ifrm.src = urls[idx];
}

setTimeout(setExternalWebsite, 0); // 最初から表示する
// 5分なら、5 * 60 * 1000 とする
var timerID = setInterval(setExternalWebsite, 5000);
}
</script>

463 = :

自ら学ぶ人とは回答者の事だったのか

464 = :

>>462
setInterval使わずにsetExternalWebsiteの最後で毎回setTimeoutすればいいだけやで

465 = :

問題にはならんと思うんだけどどんどん再起が深くなっていくのが気持ち悪い

466 = :

>>464
それってスタックオーバーフローしないの?

467 = :

スタックは積まれない

468 = :

>>467
積まれないんすね、ありがとうございます
関数ポインタみたいなのがどんどん積まれていくのかと思った

470 = :

webpackやgulpについて質問したいのですが、その類のスレッドってありますかね??。
なければここで質問してもよろしいでしょうか?

471 = :

function(t, i) {
t.target = i, e.apply(this, arguments)
}
こういう構文があったんですが
「 t.target = i;
e.apply(this, arguments);

つまりこういう構文を略して書く書き方って認識であってますか?

472 = :

>>464-468
1. function f() { setTimeout(f, 5000); }
2. setTimeout(f, 5000);

まず、2の実行では、setTimeout()は実行されるけど、f()はまだ実行されない。
つまり、キューに、fが積まれるだけ

次に5秒後、キューからfが削除されて、1が実行される。
その時に、setTimeout()で、またキューに、fが積まれる

つまり、キューには常に、fが1個しか積まれていない

>>471
わかりにくいから、そんなカンマの使い方をしない方が良い。
勘違い・バグを誘発する

普通に、; で文を区切るべき

473 :

>>472
認識があってるか確認してんだよボケ

474 = :

>>470
いいよ。他に該当のスレなんて有るわけないし

475 = :

>>453
ありがとうございました。
ローカルファイルで他サイトの呼び出しの規制に引っかかっているわけですね。
今回の案件だけ個別に許可はできないものでしょうか?(ブラウザのセキュリティ上難しい?)

476 = :

>>475
ブラウザじゃなくてサーバー側のセキュリティな

477 = :

制限をかけてるのがブラウザで
サーバはブラウザがかけてる制限を任意に解除できるだけじゃないのか
違いは無設定の鯖に対してどういう挙動になるか

というか>>451はCORS関係なんか?
みたところ子ウィンドウを開いて、子のlocation.hrefで移動させてるだけ
IE自身のセキュリティ設定、イントラネットのセキュリティポリシーな気がするんだが

478 = :

グローバル変数を1つ宣言するのと
関数を1つ宣言するのとでは
グローバルの汚染度は変わらないですよね?

480 = :

>>478
変数というのは「変えられる値」関数というのは、変えられない。

(まあ正確に言えば、JavaScriptでは関数もオブジェクトなので変えようと思えば変えられるが、
普通そういう使い方はしないしそういう使い方はグローバル変数と同様になってしまうから
ダメなやり方であるという考え方をする)

グローバル汚染というのは、値がどこから書き換えられるかわからないから問題なので、
グローバル変数はアウトだが、グローバル関数(グローバルクラス含む)は問題ない

481 = :

>>479-480
無名関数を使うとかなら、変わると言われても納得なんですけど

function ffff(){}と定義するのとvar ffff = function(){}と定義するのでは変わらないし
どちらの場合も変数名ffffに対する文字列値の再代入も関数再定義も特別の構文なしにできてしまうし
同じ名前の関数宣言があってもエラーも何も出ないのを考えると
宣言時には入れ物はどちらも変数であって(というかポインタと考えたほうが)
中身が、関数か、文字列や数値や配列やオブジェクトか、の違いでしかない、という風に思うんです

そうなると、1個グローバル変数を使うのと1個グローバル関数を使うのとでは、もはや変わりが無いように思うんですが

482 = :

ニュアンス的には幾らかの違いがあるけど、汚染度と言う視点だと無いよ
つか、関数もオブジェクトだから変えられるという言い用はJSer失格

483 = :

だからnamespace的に1つのオブジェクトに全部押し込めて汚染度下げたりしてたわけですし

486 = :

変数名が変わって困るのがそもそもおかしい

487 = :

>>486
HTMLに直接変数名が書いてあり、その変数を外部jsファイルで使用する時に使えなくなると思ったのですが。
ということは、そもそもjsの書き方がおかしいということでしょうか?
例を出せと言われてもすぐには出せませんが・・・・

488 = :

> HTMLに直接変数名が書いてあり
そんなことはしない。HTMLにJavaScriptの変数は出てこない

489 = :

uglify=難読化、minify=軽量化、全然別だ
uglifyやってんなら、そりゃそうなる

490 = :

ところでnpmに gulp-minify (-cssや-htmlがつかない)があって
minify()で普通に無駄な空白類やコメントの削除してくれるらしいが

493 = :

gulp-uglifyは詳しくないけど、
サードパーティー製のライブラリで使用しているグローバル変数(いわゆるネームスペース)を
スクリプト内で参照している場合に、その変数名をminifyしない設定があるのでは?

494 = :

>>488
多分私の説明が下手でうまく伝わっていない気がするのでちょっと考え直して
再度ご質問します。ありがとうございました。

>>489
その違いが知りませんでした。
勉強になります。ありがとうございます。

>>490
gulp-minifyですか。ちょっと試してみます。

>>492
uglify-jsも知りませんでした。
これも検証してみます。

>>493
ごめんなさい。話に追いついていけません。。。

496 = :

>>494
だからHTMLに直接変数名を書くことが
間違いだって話だよ

他のやつもやる必要のないことを書くな

497 = :

そんなの環境とコーディング規約次第だろ

498 = :

>>497
その理屈だと、腐った環境やクソなコーディング規約に
したがって開発しろって言ってるように見えるが?

499 = :

だからHTMLに直接変数名を書くことが
腐った環境やクソなコーディング規約だって話だ

500 = :

ページごと、ユーザーごとのパラメータをHTMLに書くことはあるぞ
どうせlocalStorageかHTMLに書くかAjaxで取得するかくらいしかないし


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

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


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