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

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

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

CSSで
pointer-events:none
を設定していたら
JavaScriptのイベントも起きないのでしょうか?

254 = :

ありがとうございます
JSのイベントすら無効にできるんですね~
イベントのガードに使えそう

255 = :

>>247
>ブラウザが独自拡張すれば、特別な理由はどうとでもなる

机上の空論の話をするのはやめよう。

現実に存在するブラウザの話をしよう。

未知の属性は書いても無視されるから
問題にならない。

256 = :

>>255
仕様と実装の違いを理解した方がいい
HTML4仕様の質問に実装の話をする矛盾に気が付くべき

257 = :

>>256
話逸らすなよ。

未知の属性は書いても無視されるから問題にならないだろ。

問題になるブラウザは現存しない。

お前、頭固すぎ。

258 = :

>>257
話を逸らしてるのはそちら
HTML4で問題になるかに対して実装の話を持ち出す無意味さに気がつくべき

259 = :

度々いわれてるけど、仕様と実装の違いを理解してないんだろうね

そもそも、IE6のバグの影響でHTML4時代のブラウザではgetAttributeが正しく働かないから実装上も問題はあるんだけどね
実装の話をするにしても具体的なブラウザとバージョンを示して論ずるべきでしょ

260 = :

未知の属性は書いても無視されるから問題にならない

問題になるというのなら、そのブラウザ名を言えばいい。

261 = :

そもそも、最初の「HTML4だと問題起きますか?」は厳密にHTML4の仕様を聞いてる訳じゃなくて
IE6とかで問題起きますか?と聞いてるだけだとエスパーしてみる
仕様的な事だったら起きますか?ではなくありますか?だな

仕様も大事だが、IE6含む全ての主要ブラウザで問題無い事が確認出来れば問題無い
(IE6の確認は手間なんで俺はやらんが)

262 = :

getattributeが働かないってまじですか?
jqueryはie6もサポートしていますが
attrは動かないんですか?

264 = :

element.getAttribute("class"); は比較的有名なバグだと思うけど、最近の人は知らないんだなあ
このバグの影響でほとんどの人は getAttribute を使わず、element.className を使ってた
今でも getAttribute を使う必要性はほぼないけどね

265 = :

ありがとうございます
http://stackoverflow.com/questions/7361356/how-to-get-data-attribute-in-ie-7
これによると、jqueryはie7でもうまくやってくれるようです

266 = :

getattributeで読み取れないのにどうやって読み取っているのかが謎ですが・・

267 = :

>>265
> これによると、jqueryはie7でもうまくやってくれるようです
"Of course it does not work." とあるようだけど

268 = :

は?それは質問ですが?

270 = :

なんで??
どう見ても解決してるように見えますが

271 = :

>>263が典型的な悪魔の証明やっててわろた
今時アホかよw

問題あるブラウザを言える人は
私自身を含めていませんでした。

おしまい

273 = :

>>270
jQuery.data() は data-* 属性へのアクセサメソッドじゃない
jQuery独自の機能だよ
解決法としては一般的だけど、>>266 では IE7- で data-* 属性にアクセスしていると誤解しているように読めたからね

274 = :

Web上のコードを実行するとエラーになります。
http://pc.nikkeibp.co.jp/article/column/20131028/1110088/

IE-autologin.jse
を実行すると、
行:39
文字:3
エラー:オブジェクトでサポートされていないプロパティまたはメソッドです。
となります。
何が問題なのでしょうか。
g_accouunt,gpasswordの設定はしています。
プログラミング初心者のためすみません。
よろしくお願い致します。

275 = :

>>273
You can use it with any data attribute, for example, if you had:

<div id="DivId" data-something="foo" data-somethingElse="bar">
You can get the data out by:

$('#DivId').data('something');
$('#DivId').data('somethingElse');

って書いてますが違うんですか?
IE7でとどうやるの?って聞いてるんだからIE7で可能な答え方をするのが普通の人間ですよね?
答えているのはアスペ回答者なのでしょうか?

276 = :

>>275
IE7で解決は出来るよ
誤解しているように読めたから指摘したまでだけどそうじゃなかったのならすまないね
まあ、一部勘違いしている人が現れているみたいだけど

278 = :

>>273
> jQuery.data() は data-* 属性へのアクセサメソッドじゃない

半分はずれ。

dataメソッドで読み書きするのはメモリになる。
ただしdata-*属性を読み取ることは可能。要するにdata-*属性は初期値だ。
だからdata-*属性をdataメソッドでアクセスできるかといえば半分正解になる。

dataメソッドはdata-*属性を書き換えることはできない。
どうしても書き換えたいならattrメソッドを使う。

279 = :

attrで読み書きするのはタグの属性値。
data-* というのはHTML5からできた機能だが、attrメソッドでは
data-がついているからって特別扱いはしておらず、一般的な属性扱い。
だからdata-hogeを読み書きするにはattr('data-hoge')を使用する。
attrはHTMLの仕様で定められていないものを含めて属性値すべてを読み書きできる。

280 = :

To set data:

$('#DivId').data('something', 'foo');
$('#DivId').data('somethingElse', 'bar');

とありますし、この説明からは複雑な挙動は読み取れません。
IE7でもattrを使えばdata-*属性に書き込みできるなら、
jqueryは内部でそうしているのでは?
つまりjqueryのdataを使っている限り、IEの挙動を気にする必要はないということでは

281 = :

>>278
ごめん&ありがとう
確かに僕の認識が誤っていた事を実際に jquery-2.1.0.js で確認した
で、実際にどうやって取得しているのかコードを読んでいるけど、どうにもよくわからなかった
まだまだ精進が足りないなあ

282 = :

わかった
jquery-2.1.1.js の3704行目か

// If nothing was found internally, try to fetch any
// data from the HTML5 data-* attribute
if ( data === undefined && elem.nodeType === 1 ) {
name = "data-" + key.replace( rmultiDash, "-$1" ).toLowerCase();
data = elem.getAttribute( name );

IE7- は elem.getAttribute("data-*") でもアクセスできる
突き詰めれば、elem["data-*"] でもアクセスできるという事になるのか
なかなか奇抜な仕様だなあ

283 = :

というかDOMのレベルではgetAttributeしか属性値を
取得する方法ないでしょ?

data()はjQueryの機能。

data-*属性はHTML5の仕様で自由に属性作っても違反にならないものとして
定義されただけで、昔から属性は勝手に作れる。(HTML的に違反になるだけ)
そして属性をJavaScriptから取得するメソッドは昔から変わらずgetAttribute

285 = :

IE6-8で試した人が居た
http://dasalog.eg2mix.com/jshtml5-data/

そう考えると
http://stackoverflow.com/questions/7361356/how-to-get-data-attribute-in-ie-7
これのgetAttribute()で取れないってのがあやしいんだけど
別の原因でうまくいってないんじゃないの?

286 = :

本当いつでもいつまでもIEは悩ましてくれる…IEがなきゃコードも大分スッキリできるのに…

287 = :

どっちかと言えば上の実験の方が怪しいだろ
stackoverflowは質問者だけでなく数々の回答者のチェックも受けてるんだから
間違っていれば指摘されてる可能性が高い

288 = :

いやじっさい IE7では俺の方でも試した
とれたよ

289 = :

>>271
おまえは頭脳が間抜けなのか?
「悪魔の証明」はおまえの持論が証明できないことを表しているのだが
(せっかく、>>263で悪魔の証明にならない自己弁護法を教えてやったというのに、それに気づかず悪魔の証明を持ち出すとは)

持論が証明できないから相手に反証してもらおうとはどういう理屈だ?
逆に聞くが、私が自己弁護に失敗したらおまえは反証してくれるのか?反証する必要もないとおまえは思わないのか?
あまりにもアホらしいので以降レスはしない

290 = :

>>282
よく考えたら IE7- なら jquery-1.8.3.js を参照すべきだったね
結論としては、該当コードだけなら jquery-2.1.1.js と変わりなかった

■1772行目
// Try to fetch any internally stored data first
if ( data === undefined && elem ) {
data = jQuery.data( elem, key );
data = dataAttr( elem, key, data );
}

■1806行目
var name = "data-" + key.replace( rmultiDash, "-$1" ).toLowerCase();
data = elem.getAttribute( name );

>>288
IE7- は持ってなくて試せてなかったけど、getAttribute('data-*') は期待通りに動作するのか
出来ればでいいんだけれど、下記3パターンで試してくれると嬉しい

console.log(element.getAttribute('data-*'));
console.log(element['data-*']);
console.log(element.attributes.getNamedItem('data-*').value);

291 = :

問題ないならこんな話が広まるはずもないんだから
何かはあるんだろ

292 = :

>>290
3つとも値がとれたよ
(console.logなどという高級なものはIE7にはござらぬ…)

俺もその辺のjQueryのコードを見ていて、回避コードとか無いなあと思っていて
ググって出てきたのが>>285 の前者のページ
ただ、両者の間には1年くらい間があるから、何か有ったのかもしれないけれど

293 = :

>>292
ありがとう
やっぱり、IE7- は element['data-*'] でも参照可能なトンデモ仕様なんだね
getNamedItem が使えるのなら getAttribute に頼らなければ、仕様上は問題なさそう…と思ったけど、類似バグが合ったら嫌だなあ
何度もすまないけど、下記2パターンではどうだろう?

element.attributes.getNamedItem('class').value
element.attributes.getNamedItem('className').value

前者のみで期待通りに動作するのが好ましいのだけど

> (console.logなどという高級なものはIE7にはござらぬ…)
空気のように使っていて、忘れてたー
戯言だけど、console.log は早く標準化しないかなあ

294 = :

乗りかかった船

>>293
前者は値がとれた
後者はelement.attributes.getNamedItem('className')の段階でnullだね

ちなみに getAttributeだと
alert(element.getAttribute('class')); // null
alert(element.getAttribute('className')); // class属性の値
chromeなどと逆か…

classとclassNameは昔対応した覚えがあるわ、いままでわすれてた

296 = :

面倒くせーな
ちょっとしたDOMアクセスもjquery使った方がいいってことか

297 = :

'hoge_123'
のような文字列から数値部分を取り出す簡単な方法はありませんか?

299 = :

>>289
>http://dic.nicovideo.jp/a/悪魔の証明

悪魔の証明(ラテン語:probatio diabolica)とは、「ある事実・現象が
全くないことを証明させてはならない」という論争上の原則の一つ。

概要と使い方
一般的に、「ないこと」を証明するより「あること」を証明する方が簡単な場合が多い。

例えば「未知の属性を無視するから問題ない。この点で問題が出るブラウザはない」をめぐって
「問題が出るブラウザがある派」と「問題が出るブラウザがない派」が対立した場合を考える。

(あとは面倒だから自分で単語、置き換えな)

ここで「ない派」がそれを立証するには、現在777万本以上存在する動画の中から屋外を映している
動画全てを探して閲覧し、その全てに幽霊が登場しないことを確認する必要がある。
対して、「ある派」が立証するには屋外で撮影された心霊フィルムや怪奇映像などの動画から一本探して示せばよい。

このように「存在する説」と「存在しない説」が対立した時、それらには立証する際の難易度に大きな差があることが多い。
そこで、こういった論争と証明について、その困難さなどを考慮すべきという原則を「悪魔の証明」と呼ぶ。
「ない」派が立証できないからといって、「ある」派が常に正しいとは限らないのだ。

要するに「無い(いない)ことを証明しろ!」は無茶振りである、というわけである。


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

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


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