X



+ JavaScript の質問用スレッド vol.130 + [無断転載禁止]©2ch.net
■ このスレッドは過去ログ倉庫に格納されています
0001Name_Not_Found
垢版 |
2017/07/31(月) 21:10:56.03ID:???
JavaScript を自ら学ぶ人のための質問スレッドです。
>>2-6のテンプレを読んだ上で質問してください。次スレは>>950>>2のテンプレ案(本スレで改善案があれば考慮)を元に立ててください

■規則/推奨ルール
・メール欄を空欄にし、名前にレス番を入れることを強く推奨(なりすまし防止)
・質問内容は具体的に。言葉だけでなく、出来る限り再現性を確認したサンプルコードの掲示。
・質問テンプレートの利用推奨。
・質問への「答え」だけでなく「意見」を出しても良い。

■禁止行為
・丸投げ質問
・迷惑スクリプトの質問
・オレオレ用語の使用(一般的な用語を使用する事)
・煽り、批判等の他人を不快にさせる行為(批判の代わりに「AよりBが良い」のような代案を出す事)
・回答者同士のレスは原則禁止(>>6を参照)
・ライブラリの話題の投稿(>>6を参照)

■質問テンプレート
【環境】OS, ブラウザをバージョンと共に記入してください。(ex: IE8, Firefox4)
【何をしたのか】何をしたら問題の現象が発生するのか。再現手順を具体的に書いてください。
【エラーメッセージ】エラーメッセージがあれば正確に書き写してください。(Windows なら「コピット」を活用)
【期待する結果】最終的にどういう結果を望んでいるのか、を書いてください。
【サンプルコード】現象を再現可能な最小限のコードを書いてください。
 1レスに収まらないならコード投稿サイトを利用してください。
 http://jsdo.it/ http://jsbin.com/ http://jsfiddle.net/ http://ideone.com/
0003Name_Not_Found
垢版 |
2017/07/31(月) 21:12:08.92ID:???
■FAQ
http://fiddle.jshell.net/vSqKr/44/show/light/

◆開発者ツール(Developer Tools)の基本的な使い方 (全部はhttp://fiddle.jshell.net/vSqKr/44/show/light/#Browser-Developer-Tools )
 ▼諸注意
  - 本説明では Google Chrome の開発者ツールの名称に従います。他ブラウザで使う場合は適宜読み替えて下さい。
  - IE9- でコンソールを使うには予め開発者ツールを起動しておく必要があります(開発者ツールを起動しないと console.log() が機能しません)
  - Safari はデフォルトで開発者ツールが無効な為、有効に設定する必要があります。
  https://developer.apple.com/library/safari/documentation/AppleApplications/Conceptual/Safari_Developer_Guide/GettingStarted/GettingStarted.html
 ▼要素を検証
 1. ページ上で右クリックして [要素を検証]
 2. [Elements] パネルが開き、対象のDOMノードが選択される(選択対象が目的の要素でなければ [Elements] パネル上で選択し直す)
 3. 右側のサイドバーから知りたいステータス名のタブを選択する
   - [Styles] タブ … CSSプロパティの指定値を表示 (※カスケードによって上書きされたプロパティは取り消し線で表示される)
   - [Computed] タブ … CSSプロパティの算出値を表示("font-size: 1em" を指定していても算出後の "*px" で表示される)
   - [Properties] タブ … 選択したDOMノードのプロパティを表示
 ▼コンソール
 1. JavaScript コード上で console.log('Hello, World!'); と入力
 2. [Ctrl] + [Shift] + [I] キー(IE は [F12])で開発者ツールを開き、[Console] パネルを開く
 3. [Console] パネルに "Hello, World!" と表示される
 (※window.alert() は String 型に変換されますが、console.log() は Object 型の中身をそのまま表示してくれます。)
0004Name_Not_Found
垢版 |
2017/07/31(月) 21:12:30.92ID:???
■FAQ(続き)
◆JavaScriptの実行速度
JavaScriptの速度は「ブラウザ名」「ブラウザのバージョン」「PCスペック」に依存します(ブラウザのバージョン毎に最適化具合が異なります)。
速度の疑問解消の為に http://jsperf.com/ にコードをUPしてブラウザ毎に速度計測する事を推奨します。
例外として、仕様における理論上の速度が明確になっている場合があります。
例えば、正規表現によるマッチング処理を考えた場合、「RegExp#test > RegExp#exec > String#match」は ES5 仕様で保証されています。
ES5 仕様において RegExp#test が最も処理数が少なく、String#match が最も処理数が多いことが明確だからです。
ブラウザによっては RegExp#test の最適化が十分でなく、String#match の最適化が RegExp#test より十分であれば逆転する可能性はありますが、各メソッドの最適化が一律であればこの前提が崩れる事はありません。

■各種仕様 ( http://fiddle.jshell.net/vSqKr/44/show/light/#Link も参照 )
◆ Standard ECMA-262
http://bclary.com/2004/11/07/ (ECMAScript 3 HTML版)
http://www2u.biglobe.ne.jp/~oz-07ams/2002/ecma262r3/ (ECMAScript 3 和訳)
http://www.ecma-international.org/ecma-262/5.1/ (ECMAScript 5.1 HTML版)
http://tsofthome.appspot.com/ecmascript.html (ECMAScript 5.1 和訳)
http://www.ecma-international.org/ecma-262/6.0/ (ECMAScript 6 / ECMAScript 2015)
http://kangax.github.io/compat-table/es5/ (ECMAScript 5 compatibility table)
http://kangax.github.io/compat-table/es6/ (ECMAScript 6 compatibility table)
◆ HTML Standard (HTML5)
http://www.whatwg.org/specs/web-apps/current-work/multipage/
http://momdo.s35.xrea.com/web-html-test/spec/WD-html51-20130528/Overview.html (HTML5.1 部分訳)
http://www.hcn.zaq.ne.jp/___/WEB/WebStorage-ja.html (Web Storage 和訳)
0005Name_Not_Found
垢版 |
2017/07/31(月) 21:12:46.40ID:???
■各種仕様 (続き)
◆ Document Object Model (DOM) / CSS Object Model (CSSOM)
http://www.hcn.zaq.ne.jp/___/WEB/DOM4-ja.html (DOM Standard (DOM4) 和訳)
http://www.w3.org/TR/DOM-Level-3-Events/ (DOM3 Events)
http://www.w3.org/TR/uievents/ (UI Events)
http://www.hcn.zaq.ne.jp/___/WEB/cssom-ja.html (CSSOM 和訳)
http://www.hcn.zaq.ne.jp/___/WEB/cssom-view-ja.html (CSSOM View Module 和訳)
◆ その他のWeb関連仕様
http://domparsing.spec.whatwg.org/ (DOM Parsing and Serialization - innerHTML等)
http://www.hcn.zaq.ne.jp/___/WEB/XHR-ja.html (XMLHttpRequest 和訳)
http://www.hcn.zaq.ne.jp/___/WEB/File_API-ja.html (File API 和訳)
http://www.whatwg.org/specs/ (WHATWGの仕様一覧)
◆ MDN (Netscape/Mozilla)
https://developer.mozilla.org/ja/docs
◆ MSDN Library
https://msdn.microsoft.com/en-us/library/ie/hh828809 (Internet Explorer API)
http://msdn.microsoft.com/ja-jp/library/yek4tbz0.aspx (JavaScript)
http://msdn.microsoft.com/ja-jp/library/cc427807.aspx (JScript)
http://msdn.microsoft.com/ja-jp/library/cc409712.aspx (DHTML)
◆ JavaScript Garden (ja)
http://bonsaiden.github.com/JavaScript-Garden/ja/
◆ JSON (JavaScript Object Notation)
http://www.json.org/json-ja.html
0007Name_Not_Found
垢版 |
2017/07/31(月) 21:18:10.88ID:???
クロスブラウザ問題も切り捨て時期に入りversion1の使う理由がなくる。
https://w3techs.com/technologies/history_overview/javascript_library/all
ここをみると今年に入ってからjQueryを使用している会社は0.4%増えているようだが
少数派の意見ではあるがうちの会社では年内でjQueryをきることが決まったぞ。
こういう会社もまれにあるってことを知ってほしい
0008Name_Not_Found
垢版 |
2017/07/31(月) 21:39:32.86ID:???
例外的な会社の話をするならば、
そりゃjQueryを切るところもあるだろうけど、
ぶっちゃけ、少ない方の事例じゃね?
0009Name_Not_Found
垢版 |
2017/07/31(月) 22:31:17.75ID:???
テンプレ滅茶苦茶じゃねーか
0012Name_Not_Found
垢版 |
2017/08/01(火) 05:27:35.42ID:???
>>2がぱっと見なんのライブラリ7日教えてくれ
0013Name_Not_Found
垢版 |
2017/08/01(火) 13:07:03.07ID:???
そもそもAjaxのころのライブラリ黎明期からHTML5ムーブメントまでの成長期なら分かるが
現代に主要ライブラリのリンクとか必要なのだろうか?

つうか全体的にリンクがあまりに多すぎじゃね
例えば仕様のリンクは多くてもスナップショットの和訳1つで良いだろう
最新の英語のLS版が知りたいやつがここのリンク参考にするとは思えんし

もっと言えばMDNだけで十分な気がする
MDNの各ページには仕様への適切なリンクが張ってあるし、
興味がある人ならそこから知るだろう

質問テンプレートもテンプレートなんて殆ど使われないし、
こういう質問の仕方にしてという注意事項形式に改めたり、
改善と言うか0からテンプレ作り直す必要があると思う
0014Name_Not_Found
垢版 |
2017/08/01(火) 17:09:07.30ID:???
>>13
テンプレ案で提案どうぞ スレ違い君
0015Name_Not_Found
垢版 |
2017/08/01(火) 18:18:42.11ID:???
無能にスレ違いって誰のことなんだよ?
0016Name_Not_Found
垢版 |
2017/08/01(火) 18:27:29.70ID:NaEiNuTz
スレチかもだけど
iOSでHTML、CSS、JavaScriptの編集、デバッグ(ここ重要)出来るアプリでお勧めあったら教えて
長文でも見やすくて、欲を言えばライブラリの追加とか出来ると素敵です
JSAnyWhereは試したけど、使い物にならなかった
もっと適切なスレあったら、誘導願います
0017Name_Not_Found
垢版 |
2017/08/01(火) 19:31:57.80ID:???
ここまで過疎ってる上にスレ分裂してるのにさらにテンプレ議論を別スレでさそうとは恐れいった
0018Name_Not_Found
垢版 |
2017/08/01(火) 22:58:38.87ID:???
好き勝手にやればいい
まともな質問がきて答えたければ答える
それ以外はゴミどもがくだらん喧嘩しててもスルーしときゃいい
0020Name_Not_Found
垢版 |
2017/08/02(水) 11:33:40.68ID:???
無能っていうか意図的にやってるんだよ
元のテンプレで注意されていた荒らし本人がずっとそうやってスレ立ててんの
0021Name_Not_Found
垢版 |
2017/08/02(水) 13:48:18.11ID:???
問題だー問題だーって騒ぐ割に
誰も具体的に指摘せず不備を直そうともしない
0022Name_Not_Found
垢版 |
2017/08/02(水) 14:11:24.34ID:???
いやwちっとも改善する意識の無いやつがスレを立てるなよ
ただでさえ乱立してる中立てるってことは
相当の意味を込めてないとおかしい
0023Name_Not_Found
垢版 |
2017/08/02(水) 14:56:05.51ID:???
JavaScriptが最終的に覇権握るわ。こんな応用きいて自由な言語ねえ
0024Name_Not_Found
垢版 |
2017/08/02(水) 15:05:45.36ID:???
var t = obj.typo;
こういうバグを発見できないJSは糞言語
0025Name_Not_Found
垢版 |
2017/08/02(水) 18:54:17.17ID:???
慣れればすぐ分かる
どうしても気になるなら存在しないときエラーを出すProxyで包んだりすればいいじゃないか
0026Name_Not_Found
垢版 |
2017/08/02(水) 20:45:42.89ID:???
効率は悪いがメモ帳みたいな最低限の環境でもできなくはないし、
1発とはなかなか行かないが問題なく動くものも作れるけど、
存在しないあるいは未参照だったりするオブジェクト・変数・メソッドをチェックしてくれるぐらいの環境は用意したほうがいいんじゃね。
そこまで本格的でなくても、typo程度ならシンタックスチェック入れるだけでもだいぶ変わるはず。
0027Name_Not_Found
垢版 |
2017/08/02(水) 21:30:45.31ID:???
typoは確かに良くするが大抵すぐ分かるけどな
コンパイルしてデバッグ実行のオーバーヘッド考えたらさほど大したことじゃないと思う
それよりも近年たまにハマるのがイテレータ周りだな
例えばPromise.all([a,b,c])としないといけないところをall(a,b,c)としてしまうと
undefined is not a functionエラーが出てしまう
これがall(a,b,c)ならまだ原因に気づきやすいんだろうが、
async関数の絡みでよくall(a(),b(),c())となってることも多いので惑わされる
0028Name_Not_Found
垢版 |
2017/08/02(水) 21:59:04.57ID:???
ブックマークレット作成してて、画面項目入力後にボタンクリックして次の画面に遷移。遷移先でも入力させたいんですが、描画完了直後に入力したい場合どうすればいいでしょうか?
0029Name_Not_Found
垢版 |
2017/08/02(水) 22:41:35.34ID:???
Proxyを無理やり使って実行時に判明する程度だからな・・
静的にobjのプロパティ参照typoを見つけられるチェッカーは無いし
0030Name_Not_Found
垢版 |
2017/08/02(水) 23:02:10.45ID:???
>静的にobjのプロパティ参照typoを見つけられるチェッカーは無い
ないの?知らんけど
探せば普通にありそうだけどな
0031Name_Not_Found
垢版 |
2017/08/03(木) 03:09:11.09ID:???
変数とは勝手が違うから難しそう
多分Object.prototype.__proto__にProxyを挟むというのが良いかもね
0032Name_Not_Found
垢版 |
2017/08/04(金) 11:18:22.82ID:???
typoが気になるならTypeScriptおすすめ。
基本的は

let a:型 = ほげほげ

みたいに型を:の後に追加するって仕様だけで使える。
後、個人的に気に入ってるのはjsonにスキーマ設定できる

interface User {
name: string
age: number
}

user:User = {
name: 12 // error!
// ageが足りない!
}
って感じでエラーを出してくださる。
jsonにスキーマがつくとすごく便利よ〜。
0033Name_Not_Found
垢版 |
2017/08/04(金) 11:22:21.22ID:???
https://www.typescriptlang.org/play/

上記とかtypscriptがどんな感じかわかるから触ってみて
シンプルな見た目のくせに補完が効くしね。
試しにdom操作してみると感動するで

document.createElement とか使ってみて欲しい
document.createElement("button”)を実行するとちゃんとHTMLButtonElement型が代入されてるしそもそもdocumentって入力しただけで
候補が出るからtypoしようもないよね。
0034Name_Not_Found
垢版 |
2017/08/04(金) 13:18:13.38ID:???
確かに素晴らしいんだけど
大規模コード書くようなTSが有用なときって
あんまりそう言う重し付けたくないんだよね

何が嫌かって言ったらリリースデータに元とコンパイル後の2つ含めることになること
ポリフィルみたいに簡単に要らなくなったら外すとかできないし
0035Name_Not_Found
垢版 |
2017/08/04(金) 13:56:34.28ID:???
>>34
最悪tsを捨てちゃったっていいのよ。
生成されるファイルはtargetをes2015にして出せばそんなにはキチガイなコードにはならないからjsとの混在も可能だしね。

ちょっと前は型定義ファイル周りのエコシステムが乱立?して混乱を呼んだけど
今は平和だしいい感じよ。

俺はむしろtypescriptからjsに本格入門した。
vscodeで書いてるというのもあるけど、書いてる最中にバグを指摘してくれるから
気分的にはコンパイラとペアプログラミングしてる感じ。

いちいちドキュメントを見に行かなくてもvscodeが必須パラメータを教えてくれる。

感覚的には文字入力してる時に頭の悪いIMEから頭のいいIMEに代わって
凄く捗るぜーって感じかな。
0037Name_Not_Found
垢版 |
2017/08/04(金) 20:23:35.94ID:???
>let a:型 = ほげほげ
>みたいに型を:の後に追加するって仕様だけで使える。
インタプリタに慣れすぎて型指定するのめんどくさいお
0038Name_Not_Found
垢版 |
2017/08/04(金) 21:21:05.97ID:???
>>37
型推論使えるから基本関数とかメソッドのインターフェース定義のときしか要らないよ。
0039Name_Not_Found
垢版 |
2017/08/05(土) 17:09:35.45ID:???
>>22
これ
能力無い奴が余計なことして後手後手になる典型的なパターンなんだよな
0040Name_Not_Found
垢版 |
2017/08/07(月) 16:42:22.61ID:ZV9geJvA
自己流で覚えたので、おかしなやり方をしてる気がしてるのですが、どうもstring.match(/hoge/)が使いにくいのです

正規表現マッチだとオブジェクトで帰ってくるので

var temp = string.match(/.*hoge/).replace("honya","hage") ← stringじゃないのでエラー
var temp = string.match(/.*hoge/)[0].replace("honya","hage") ← マッチしなかった場合0なんてプロパティはありませんとエラー

となり良く止まってしまいます
これを判別して

var temp = string.match(/.*hoge/)
if(temp != undefined){
var temp2 = temp[0]
} else {
temp2 = ""
}
temp = temp2.replace("honya","hage")

と書くと、ただストリングがひとつ欲しいだけなのにいちいち長くなってしまいます
そこで

var temp = (string.match(/.*hoge/) || ["","",""])[0].replace("honya","hage")

最終的にこんな書き方になりましたが、見づらいし、こんな泥臭いというか力業が一般的な書き方とは思えず悩んでいます
そこで皆さんがどうやってるか・一般的にはどうやるのか、どうかアドバイスください
0041Name_Not_Found
垢版 |
2017/08/07(月) 17:59:51.55ID:???
var temp = string.match(/.*hoge/), temp2 = temp && temp[0].replace("honya","hage");
var temp = string.match(/.*hoge/).map( m => m.replace("honya","hage") ) [0];

ある程度はどうしようもない
0043Name_Not_Found
垢版 |
2017/08/07(月) 18:42:08.10ID:???
愚直にやるのが一番いいと思うけど。
ワンライナーにしなきゃいけない理由がわからない
三ヶ月後の自分が分かるコードで書くべき
0044Name_Not_Found
垢版 |
2017/08/07(月) 19:30:51.85ID:???
こんなコード書かれたら発狂するわ
0045Name_Not_Found
垢版 |
2017/08/07(月) 20:45:20.80ID:???
>>41
&&をこんな感じに使えるんですね、なるほど参考になります
ありがとうございます

>>43
長いと目が迷子になってしまうので、特にmatchはよく使うので
一般的な感覚じゃないかもですが、行数の割に得られるものが少ないと、このブロック何の為だ、と後々読んだ時に混乱してしまって
でもif文で数行に書くのが一般的なのですね、なるほどありがとうございます
0046Name_Not_Found
垢版 |
2017/08/07(月) 22:00:11.62ID:???
string.match(/(.*hoge)/)
temp = RegExp.$1.replace("honya","hage")
0047Name_Not_Found
垢版 |
2017/08/08(火) 02:08:12.03ID:???
>>46
これRegExp.$1に何も入ってなくてもエラー吐かないんですね
こんな裏技あったとは、RegExpって気になってたので意識して使ってみます、ありがとうございます
0048Name_Not_Found
垢版 |
2017/08/08(火) 04:59:19.20ID:???
条件が複雑なら、コードも複雑になるのが、当たり前。
そのまま素直にコードにすればよい

条件が複雑なのに、コードが単純になっていれば、間違っている。
コードを単純に出来るなら、条件も単純に出来るはず

2段階のプロセス。
1. 論理的に正しい証明を先にしてから(仕様書)、
2. その通りにコードに写す(実装)

2を修正したら、常に1に帰ってから、正しさを証明して、2を修正する。
常に、考える時は、1の仕様書で考える

&& を使ったら、if-else よりも、分かりにくい。
頭の中で、if-else に置き換えて、
論理的に矛盾が無いか、証明しないといけないから、余計に難しい。
つまり、見落とし・勘違い・バグが起こる、可能性が高くなる

もし、&& の右の式に、副作用があって、何かの状態を変える場合、
パッと見て、右式が実行されたか、されていないか、分かりにくい。
頭の中で、間違いが無いか、確かめるのが大変

論理的に正しいと証明するのが、一番難しい。
コードを書くよりも難しい
0049Name_Not_Found
垢版 |
2017/08/08(火) 08:57:46.63ID:???
ECMAでRegExp.$1などを無くそうかという議論がされてるときに
堂々と提案できるやつはどういう神経してるんだろう
0050Name_Not_Found
垢版 |
2017/08/08(火) 09:31:44.99ID:???
なくなってからまたおいで
10年後ぐらいにね
0051Name_Not_Found
垢版 |
2017/08/09(水) 02:51:27.94ID:???
なくそうか、じゃなくて仕様に拡張として追加しようか、という案と反対意見でしょ
現時点ではただのレガシーな独自実装なんだから、勧めるのは確かに良くないよ
0052Name_Not_Found
垢版 |
2017/08/09(水) 09:45:36.44ID:???
やっぱそうだったかw
無くすわけないしな

全てのブラウザで使えて昔から
よく使われているものなんだから
仕様に追加するべきだろうな。

昔から広く実装されているからって
レガシーってことにはならんよ
0053Name_Not_Found
垢版 |
2017/08/09(水) 22:36:56.14ID:???
よく使われている……?
キチガイじみててめまいがしてくるなw
0054Name_Not_Found
垢版 |
2017/08/09(水) 23:50:53.63ID:???
HTML5っていうのはそもそも過去のブラウザを含めて各ブラウザで
同じようにレンダリングできるように仕様が固められたもの
仕様があってそれに準拠するようにブラウザを開発するのとは逆。

だからJavaScriptでも同じように動くことを目標としてるので
使われている機能は消さないし、標準化されてないのであれば
標準化する方向にすすむ。
0055Name_Not_Found
垢版 |
2017/08/10(木) 07:50:42.87ID:???
>>39
基地外が立てたスレだから許してやれ
0056Name_Not_Found
垢版 |
2017/08/10(木) 09:36:53.61ID:???
>>54
「JavaScript」の仕様があればそうだし、現にWHATWGにはRegExpの拡張を含む「JavaScript」仕様があった
での削除された、その理由を考えると良い
0057Name_Not_Found
垢版 |
2017/08/10(木) 19:06:04.88ID:???
ちょっとスレチかも知れないのですが
<video src="blob:https://google.com/example";>
のsrcのblobって何を表しているのでしょうか?blob先のURLにアクセスしてみても404なのですが
0058Name_Not_Found
垢版 |
2017/08/10(木) 20:26:08.60ID:???
data:image/png;base64,〜のようにDataURIは知ってると思うがそれの親戚だ
よりでかいバイナリデータを扱う場合に適しているAPI
0059Name_Not_Found
垢版 |
2017/08/10(木) 21:16:14.19ID:???
>>56
あー、考えたw 考えたw
はい、この話題はおしまい
0060Name_Not_Found
垢版 |
2017/08/10(木) 21:17:05.02ID:???
>>58
そういうことを聞いてるんじゃないだろ
説明が的はずれだな
0061Name_Not_Found
垢版 |
2017/08/10(木) 21:22:34.09ID:???
どこが的はずれなんだ?何を表してるって聞かれてバイナリオブジェクトってまんま答えなわけだが
0062Name_Not_Found
垢版 |
2017/08/10(木) 21:33:50.04ID:???
>>58
有難う御座います
すみません詳しい説明の乗ってるサイトとかってありますか?
404のページのURLが何を表してるのか分からなくて
0063Name_Not_Found
垢版 |
2017/08/10(木) 21:39:29.98ID:???
Q. srcのblobって何を表しているのでしょうか?

A1. バイナリデータを扱う場合に適しているAPIだ!
A2. バイナリオブジェクトだ!


的外れは続くよw
0064Name_Not_Found
垢版 |
2017/08/10(木) 21:49:48.50ID:???
メモリ上にあるオブジェクトに発行した一時的なIDみたいなもんでそのページのみで有効
普通にいつでもどこでもアクセス可能なURLではない
0066Name_Not_Found
垢版 |
2017/08/10(木) 23:51:26.90ID:???
blob は Binary Large Object の略称だから的外れでもない
0067Name_Not_Found
垢版 |
2017/08/11(金) 07:41:17.24ID:???
>>65
動画サイトなら手軽にアクセスできなくしてるのだろう
直リンで見れるようなら自分が持ってる動画プレイヤーや
第三者サイトの動画プレイヤーやとかで見れてしまうわけで
そうすると広告のある自サイトに誘導出来ないから困っちゃうとかね
0068Name_Not_Found
垢版 |
2017/08/11(金) 09:17:38.63ID:???
Blobと言うのは要するにプログラム中に存在するファイルデータみたいなもんだよ
そんでそのURLはそのデータを参照させるためのもの
つまりブラウザ内に存在しているデータへのリンクであって、
そのデータはどこかから取ってきたものかもしれないが、
blobURLが外部へのURLに置き換わるわけではない
0069Name_Not_Found
垢版 |
2017/08/11(金) 09:20:46.41ID:???
Firefoxスレで質問してみたのですが答えが返って来なかったのでご存知の方お願いします

Fullscreen APIでflashをsrcに指定したiframe要素をフルスクリーン化したあと
フルスクリーン化したiframe内を左クリックすると元に戻っていたのですが
先日リリースされたFirefox55になってからこの方法では戻らなくなり
ESCキーを押した時に戻るようになりました
Firefox55でも引き続きフルスクリーン化の脱出に左クリックを使いたいのですが
何か情報ありませんでしょうか?
0070Name_Not_Found
垢版 |
2017/08/11(金) 09:25:36.12ID:???
その話は知らんけどflashは2020年には廃止されるようだな
0071Name_Not_Found
垢版 |
2017/08/11(金) 12:58:38.70ID:???
フルスクリーンのUIはずっと固まってないじゃん
Chromeでもオプション提供してずっと実験してるし
今たまたま望み通りいってることがこの先も上手くいくとは限らないと考えるべきだよ
0072Name_Not_Found
垢版 |
2017/08/11(金) 13:01:52.59ID:???
まあdocument.exitFullscreenをうまく使う位しか望みは無いんじゃないの?
007369
垢版 |
2017/08/11(金) 13:16:13.10ID:???
>>70-72
レスありがとうございます
Firefoxの場合設定いじったり加えると戻ったりするのですが今回は見当もつきませんでした
JavaScriptで制御できればいいんですけどね
iframe側はflash直接埋め込んでるのでJavaScript使えないので
フルスクリーンにしてフォーカスがiframe内に移ってしまうとどうしたらいいかわからないです
iframeが動作が軽快なのでiframeをどうしても使いたいため
objectやembed使う以外でなんかうまい解決策とかありそうでしょうか?
0074Name_Not_Found
垢版 |
2017/08/11(金) 14:50:01.47ID:???
iframeが動作が快適だと考えるのも危ないと思うよ
今ちょうど各ブラウザがiframeの優先度やどういうプロセスで動かすか大改造中だもの

で、iframeが同オリジンなら操作できるかもね
007569
垢版 |
2017/08/11(金) 17:29:12.90ID:???
>>74
iframeを参照するhtmlもiframeのsrcのflashも同じオリジンです
localhostで使っているものなので
そうするとflash側のソースをいじらないといけないんですかね
一応オープンソースなのでソースはいじろうと思えばいじれるのですが
ActionScriptはさっぱりです
007657
垢版 |
2017/08/11(金) 18:13:46.16ID:???
>>68
"blob:https://google.com/example";というのは、いったんブラウザメモリへダウンロードしたファイルへアクセスさせる変数ということで合ってますか?
しかし動画ファイルだと数ギガあったりするので
「はい今数ギガの動画を一瞬でダウンロードしたのであとはローカルでアクセスしてください」ってことになっておかしい気がするのですが
どこか認識が違ってるでしょうか?
0077Name_Not_Found
垢版 |
2017/08/12(土) 05:40:45.04ID:???
そうだけどメモリとかよりはもっと抽象的に考えたほうが良いとは思うよ

それで動画はチャンクで細切れに送られてくるものだから
MediaSource APIを使って随時結合していってるんじゃないの?
0078Name_Not_Found
垢版 |
2017/08/12(土) 09:18:14.70ID:???
>>77
そんなAPIがあるんですね。つまり動画を見てる時、再生時間が変わる度に
再生時間に合わせた細切れ動画をダウンロード→blob:http://~~のリンクを今ダウンロードした場所へ変更→blob:http://~~の内容が変わったことをブラウザが感知して新しい動画が再生される
という感じですかね
どうも有難う御座いました
0080Name_Not_Found
垢版 |
2017/08/15(火) 09:16:47.49ID:???
完全に取り残されて、最新の情報に追いつけないのですが、
10年前のコードから、順を追って現在のコードに変えていきたいのですが、
何か最適な学習法やサイトありませんか?
0081Name_Not_Found
垢版 |
2017/08/15(火) 16:09:23.61ID:???
必ず覚えておきたいという物は少ない
便利機能や雑多なもの、細かい難しい点についてはざっと眺めとくだけでいい

まずばletやconstだけど、どんな説明見ても一回で分かるだろう
次にclassだけど、これも重要な点はすぐ理解できると思う

一番の問題はPromiseかもしれない。
まあググって上の方のページ見とけば良いんだけど、
機能や使い方だけではなく、概念を理解しないといけないから
頭の柔軟度などに依存して難しいかもしれない

あとは本当に自分で自分のために使っていって慣れるしか無い
Promiseはこれから普及するasync関数で真価を発揮する
だからまだ取り残されては居ない
2020年くらいまでは猶予がある
0082Name_Not_Found
垢版 |
2017/08/15(火) 16:13:53.86ID:???
ESの変更については上記の通りだが、
Web APIについては、進化点を探すのが難しいかもしれない
取り敢えず自分が情報追うのに使っているのは、このChromeの実装計画

https://www.chromestatus.com/features
ここを左の下のVersion 1から順に選んで見ていったら良いかもしれない
追加だけでなく廃止された重要な点も書いてある
0083Name_Not_Found
垢版 |
2017/08/16(水) 12:18:40.28ID:???
無理だとは思いますが、
Windowsのスタンバイ時、スタンバイ復帰時に、
開いていたブラウザでイベントを起こすことってできますか?
0084Name_Not_Found
垢版 |
2017/08/16(水) 17:23:22.09ID:???
似たようなことはできるよ。
調べるの面倒なんで
例のWeb APIマニアさん頑張ってw
0085Name_Not_Found
垢版 |
2017/08/17(木) 18:55:40.07ID:???
出来ると知っているのに「調べるのが面倒」とはどういう意味だ?
0086Name_Not_Found
垢版 |
2017/08/17(木) 22:03:58.40ID:???
あー、あの関数でできそうだよ
関数名忘れたけど
0087Name_Not_Found
垢版 |
2017/08/18(金) 01:55:02.43ID:???
知ったかして、詳しい人が解説してくれるのを待つテクニックか
0088Name_Not_Found
垢版 |
2017/08/18(金) 06:26:46.95ID:???
自分も気になって横から知ったか書き込みしたんだろうけど
スレの雰囲気も悪くなるしただ迷惑
0089Name_Not_Found
垢版 |
2017/08/18(金) 08:41:22.65ID:???
横着な方法だけど、1秒毎に時間測って一定以上感覚開いていないか調べれば良いんじゃないの?
0090Name_Not_Found
垢版 |
2017/08/20(日) 17:42:43.39ID:???
Promise は過渡期に出来てしまったから、.method() な連結記法が鳥肌ものにダサい。
0091Name_Not_Found
垢版 |
2017/08/21(月) 23:52:00.46ID:???
えー超便利だけどじゃあどういうのがいいわけ?
0092Name_Not_Found
垢版 |
2017/08/22(火) 14:15:50.77ID:???
Promiseってなんじゃ?xhrじゃだめなんけ?
0093Name_Not_Found
垢版 |
2017/08/22(火) 16:26:05.23ID:???
Promiseは昔っから概念がある物だしESでも1年以上十分に練られただろうよ。
0094Name_Not_Found
垢版 |
2017/08/23(水) 11:19:26.79ID:???
Promiseはasync-awaitと組み合わせてこそ最強
0095Name_Not_Found
垢版 |
2017/08/23(水) 14:02:45.98ID:???
awaitぐらいasync無しに単体で使わせろよと思う
0096Name_Not_Found
垢版 |
2017/08/23(水) 18:18:35.52ID:???
>>92
時間掛かる処理の場合、続けてなにかやりたいときは
コールバックで渡すからやりたいことがいくつもあると
どんどんネストしていくことになるじゃん?

promiseはそうではなく、メソッドチェーンで繋いでも
ちゃんとひとつひとつの処理が終わるまで待ってくれるやーつ
0097Name_Not_Found
垢版 |
2017/08/23(水) 22:42:43.34ID:???
今electronやっててjqueryで要素の編集とかで練習してんだけど
electronとjqueryの相性悪いのとjquery単体で画面パーツとか無いから新しいライブラリ探してるんだけどいいのないですかね??
色んな画面パーツとそこからのイベントが簡単に用意出来ればいいんだが
0098Name_Not_Found
垢版 |
2017/08/24(木) 10:27:54.81ID:???
>>97
reactとかvue.jsとかかね。vue.jsが無難
0099Name_Not_Found
垢版 |
2017/08/24(木) 20:22:12.86ID:???
サーバサイドのデータをクライアント側で編集するタイプのアプリを作っていますが
サーバサイドの状態とクライアント側が前提としている状態が
ズレた時の問題について考えています
データ変更のたびに変わっていくバージョン情報を設定し
クライアントが読み書きする時にはサーバに自分が所有しているバージョン情報を渡し、
それがズレていたらサーバは差分情報をクライアントに返し、
クライアントは差分を自分に適応する、
というような方法がいいのではないかと思ったのですが
もっといい方法ありますか?
あとこういうアプリのサンプルが載ってる本とかあれば教えてください
0100Name_Not_Found
垢版 |
2017/08/24(木) 20:29:16.60ID:???
>>97
これ立ち読みしてみ。
https://www.amazon.co.jp/dp/4774188190

どんなクオリティであれ自分が勉強してる分野の紙の本が出てるってすばらしい!
検索しなきゃいけない量がめっちゃ減るからね。
■ このスレッドは過去ログ倉庫に格納されています

ニューススポーツなんでも実況