7cc@はてなブログ

JavaScriptとかとか

Windowのコマンドラインでドライブ変更 (Git shell)

普通のコマンドプロンプトと、Git Shellとで書式が異なる。`pushd c:/` なら両対応。

ニコニコ動画で、ユーザーIDからニックネーム(ユーザーネーム)を取得する

ポイント 公式のAPIが無い&公開されてはいないので、「マイページを直接叩くよりはマシ」という程度の認識で使う。 確実に取得する方法はないので、ユーザーネーム取得に失敗した時のためにダミーテキストを用意してやると良い。 戻り値が空文字やnullでエラ…

visibility: hidden と display: none の違いは2つ

CSS

この2つのCSSの違いについてはよく、「visibility: hiddenは空白を残す」ということだけ説明されている。しかし、詳しく説明するとそれ以外の違いもある。

多次元配列の再帰の記述

記述の方法が、foriで書くと1通りだが、イテレートメソッドだと2通りある。 どちらでもよいのだけれど、混ざるので整理。 foriとイテレートはすることが少し違うが、それは置いておく foriでの再帰。(コード1) function fori(arr, fn) { for (var i=0, l=a…

img.width, img.height と img.setAttribute("width"/ "height"

JSからサイズを設定する場合 OK img.width = "100" img.setAttribute("width", "100") img.setAttribute("width", "100px") NG img.width = "100px" IEとFirefoxで試して両方こうだった。罠くさい・・・ といっても、本来<image>のwidth, heightに入れられるのは数</image>…

ネイティブメソッドを判別する互換性

setTimeout, setIntervalを乗っ取って爆速にする - 素人がプログラミングを勉強…を踏まえて "prototype" in Arrayはすべてtrue "prototype" in Array.prototype.pushはすべてfalse "prototype" in function(){}はすべてtrue "prototype" in {native dom func…

(JavaScriptで使われる)数学の英語 数字編

JSで使われる数学に関した英語の和訳。 digit(s) 0-9の数字(0は除かれることも), notation 表記, integer 整数, decimal 小数 / 10進数, fixed-point number 固定小数点数, floating-point number 浮動小数点数, precision 精度

はてなブログのテーマのライセンスに、GPLが選べるようになりました

アナウンスは(まだ)無い。 なぜGPLが選べるようになったのか Hatena2 for はてなブログ - テーマ ストア - はてなブログ のように、「はてダ」、はてなダイアリーのテーマがいくつか「はてなブログ」に移植されている。CCライセンスで。しかしこれはGPLに…

IEで「オブジェクトを指定してください」のエラー

言い換えると分かった。 「オブジェクトを指定してください」 「オブジェクトが指定されていないよ」 「オブジェクトが無いよ」 「オブジェクトがundefinedだよ」 原因 3通りあるようだ 原因1 古いIEと文字コード IEの謎エラー対策(1) 「オブジェクトを指定…

はてなブログでのMarkdownの不具合・仕様

不具合報告も兼ねて。 報告済み・仕様との回答を頂いたものは見出しに記載。 Markdownはパーサが色々有り、またサービスによって独自の機能を提供しているものもあるので、なかなか厄介だと思った。 はてな GitHub 普通の環境 の3つで試した。 普通の環境 は…

objectの中のobjectを書き換え不可にする

JavaScriptのオブジェクトを完全に書き換えできないようにするには、`Object.deepFreeze`と`Object.defineProperty`を併用する。

CSS transformが効かない

CSS

CSS transformの適用される要素は決まっている。transformable elementsと呼ばれる。 transformable elements(変形可能要素) Block-level elements atomic inline-level boxes: replaced inline-level elements, inline-block elements, and inline-table el…

element.ownerDocument.defaultView.frameElement

複数のwindowを扱う場合。iframeとwindow,documentのトラバーサルについて。関連ワードownerDocument.defaultView, contentDocument.defaultView, window.frameElement

JavaScriptでグローバル変数になるものの、優先順位

要素のIDや、iframeのname属性もグローバル変数になる。

You might not need jQuery は間違いだらけ

すこし話題になっている(いた?)ようだが、jQueryを使ったことの無い私が気付いただけで間違いが10個あった。 サイトはここ GitHubにソースがある 見つけた間違い 60個あるうち10個 つまり全体の1/6, 16.6% 内容についてはレポジトリ参照(そこまでする利点…

デバッグ時だけconsole出力したい

var debug = true if ( !window.console || !Function.bind ) { debug = false } var cl = debug? Function.prototype.bind.call(console.log, console) : function(){} usage cl(1, 2) console.log.applyだと出力箇所が関数定義場所になってしまうのでbind…

document.activeElement

focusのある要素を返す。 リンク、tabindex、IEでのdivなど互換性についても説明。

ownerDocument, document

JavaScriptのownerDocumentとは。 いつ使うのか。

element.onresize

まだ使えない。 element.addEventListner("resize", ... について

Google ChromeのCSSOMは相変わらず間違っている

追記 ver. 33.0.1750.117 m でCSSOMの実装が以前のバージョンに戻った。今は下記のエラーは表示されない しかしこの実装は間違っているので、将来的には変更があると思われる。 以下は追記以前の情報

IE開発者ツールの不具合 / デバッグ時の注意点

環境は全てIE9。10+では不明 IE9 console 開発者ツールを開いていないと、そこで止まる location.hash ローカルファイルだと、戻る/進むでロケーションバーに表示されなくなる。実際にはある。 非ascii文字のID + エンコードされたページ内リンク の :target…

addEventListenerのhandleEventについて

オブジェクト(指向)で使うようです。 syntax プロパティにhandleEventがあるオブジェクトを第二引数に渡す。 handleEventの値はfunction // 変数に入れて var foo = { v: 1, handleEvent: function(){ alert(this.v) } } document.addEventListener("click",…

xhr GETのキャッシュ

XMLHttpRequest GET のキャッシュについて ・・・なのだけれど、xhrだけではなく、キャッシュ全般にいえる話だった。 キャッシュの仕組みについては以下のリンク参照。 事例に学ぶWebシステム開発のワンポイント(12):ブラウザキャッシュでパフォーマンス…

event handler(2) onClick属性とonclickプロパティ

イベントハンドラについて。HTML属性とscriptでonclickを設定する時の違いについて。

event handler(1) 簡単なイベントハンドラのメモ

仕様書 Events - whatwg を読んだメモ GlobalEventHandlersとかWindowEventHandlersについて 普通の説明はいくつものサイトでされているので省略 DOM event handlers - MDN

ドットインストールのCSSを見るなら注意

ドットインストールという動画でプログラミングを学べるサイトが結構?人気・評判のようだ。しかし、どうしても動画が良い、というのでないなら見ないほうが良いと思った見るなら注意が要る。 好みの問題ではなく間違い・非推奨な内容が含まれているからだ。…

CSS transition + display:none は子要素があれば出来る

CSS

あるいは親要素があれば。 方法 子要素でdisplay切り替え 親要素でtransition

a.download + data:text/plain or Blob でテキストを保存したら改行がLFになった

一行ならCRLF, 改行があるとLFで保存されて困った。 CRLFなので当然環境はWindows

FirefoxでGistやgoogle-code-prettifyをコピーしたときのインデントを正常化する

Gistやgoogle-code-prettifyをコピーした時のインデントを見た通りに直す

Firefox 開発ツールのJavaScriptショートカット関数

FirefoxのWebコンソールとScratchpad(スクラッチパッド)で使える$x, $0, $, $$