Jul - 14th

くらえiPhone!

Posted at 1:04 pm | Filed Under Apple, Javascript

iPhoneでアクセスしてきたら、とりあえず先に90度回転しておいて、縦にしても横にしてもずっと画面が傾いたままにしてしまえばいい。(参照

Safariでアクセスして動いてたからたぶんこれで大丈夫だ。

iPhone専用ページ

update: 実機を借りたので試してみたらだめだった。畜生め。
update2: いちおう動いていた。
update3: くそっ!Windowの幅や高さが変わったら回転するというのはできなかった。画面をフリップさせてもwindow.outerWidthやwindow.outerHeightの値は変わらないらしい。

function flipYou(){
        document.body.style['-webkit-transform']='rotate(90deg)';
        height = window.outerHeight;
        base = 90;
        setInterval(function(){
                if(height != window,outerHeight){
                        base += 90;
                        com = 'rotate(' + base + 'deg)';
                        document.body.style['-webkit-transform']=com;
                        height = window.outerHeight;
                }
        }, 5000);
}

これではちゃんと検知しない。heightをwidthにしてもダメ。

Read More>

Jun - 11th

クッキーモンスター

Posted at 7:02 pm | Filed Under Fun, Javascript

ファイル名や変数名にはみんないろいろこだわりがあると思うが、同好の士を見つけるとうれしくなる。

live365.comのプレイリスト表示ページのソースだが、クッキーを扱うらしきJavaScriptの名前に驚いた。3年くらい前から、仕事でもクッキーの名前の一部や何かのキー、関数名、変数名に自分でもこの名前を使っていたので。

Read More>

Apr - 10th

使い道がわからん

Posted at 11:02 am | Filed Under Javascript, PHP

もうすぐ廃止になるJavaScriptのescape関数なのだが、例えばこんな風に文字列をescape関数に渡すと

<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8" />
<script language="javascript">
function test(){
	var str = document.getElementById('tibet').innerHTML;
	var esc = escape(str);
	alert(esc);
}
</script>
</head>
<body>
<div id="tibet">ダライラマ</div>
<button onClick="test();">test</button>
</body>
</html>

alertに表示されるのは「%u30C0%u30E9%u30A4%u30E9%u30DE」という書式になっている文字列で、ようするにescape関数は文字列を%uで始まる16進数のかたまりにする。

これをそのままPHPに渡してデコードするには、

<?php
$str = '%u30C0%u30E9%u30A4%u30E9%u30DE';
$decode = preg_replace_callback("/(%u)([0-9a-zA-Z]+)/", '_decode', $str);
function _decode($array){
	return mb_convert_encoding(pack("H*", $array[2]), 'UTF-8', 'UCS-2');
}
?>

こんな感じで処理する。逆に、PHP側で文字列をJavaScriptのescape処理と同様に加工する場合は

<?php
$str = 'ダライラマ';
preg_match_all("/(.)/u", $str, $matches);
foreach($matches[1] as $k => $v){
	$matches[1][$k] = '%u' . strtoupper(bin2hex(mb_convert_encoding($v, 'UCS-2', 'UTF-8')));
}
$encode = implode("", $matches[1]);
?>

でできる。

と、ここまではいいのだが、JavaScriptでエスケープ処理された文字列をやり取りして面白いことができないか考えても、特に何も思いつかないので困った。

Read More>

Oct - 26th

Yahoo! JapanでJavaScriptのエラ_

Posted at 1:21 am | Filed Under Javascript

Yahoo! Japanのトップページにアクセスすると、デバッグモードにしてLog JavaScript ExceptionsをオンしたSafariではコンソールに

http://www.yahoo.co.jp/:TypeError - Value undefined (result of expression hm.isHomePage) is not object.

というエラーが出てくる。なんだろう。たぶんここに書かれているのと同じだから、Operaでも再現するらしい。というわけでFirefoxで開いてみたのだが、

Yahoo

これじゃねえの?

Read More>

Oct - 22nd

dieとexit

Posted at 10:35 am | Filed Under Javascript, PHP

exit関数(dieはこのエイリアス)の引数に文字列を渡すと、メッセージとして文字列を出力してスクリプトが終了するのだが。

PHP4.2以降ではintegerを渡すと終了時のステータスコードになる。0は正常終了なので、適時利用すればいい。利用できるのは254までの整数で、255は予約されている。

255を越える値を渡すと無視される。

で、何が言いたいのかというと、

public static function response($str){
    header('Expires: ' . gmdate('D, j M Y H:i:s', 1));
    print("\xef\xbb\xbf");
    die($str);
}

うっかりこんなコードを書くと、$strに整数しか入っていない場合は何も出力されない。Ajaxでサーバ側からのレスポンスを記述するときによくやってしまいがち。

public static function response($str){
    header('Expires: ' . gmdate('D, j M Y H:i:s', 1));
    print("\xef\xbb\xbf");
    print($str);
    exit;
}

これが正しい。って、自分がやってしまったわけですが。

Read More>

Sep - 1st

Prototype Portal Class

Posted at 2:06 am | Filed Under Javascript, Software

コンテンツをブロックに分けて、それぞれをWidgetと称して自由に位置を変更したり非表示にしたりするJavaScriptライブラリ、Prototype Portal Classyoumosで紹介されている

PCサイト向けCMSのページ編集機能なんかに使えるな、と思ったら、これってJetspeedの画面みたいだな。

Read More>

Aug - 15th

TinyMCEとページ内リンクのURL

Posted at 9:41 am | Filed Under Javascript

TinyMCEでページ内のアンカーにリンクを挿入しようとすると、#で始まるURLは勝手に親ページのURLを拾ってきて補完して絶対パスに変換してしまう。

http://hoge.com/hoge.cgiにて動作させる
リンクアイコンをクリック
ポップアップ画面のリンクのところに「#test」と入力
リンクを挿入してポップアップ画面を閉じる
HTMLを確認 ← 「http://hoge.com/hoge.cgi#test」に補完されている

という感じ。該当箇所はlink.js。

// Make anchors absolute
      if (href.charAt(0) == '#')
              href = tinyMCE.settings['document_base_url'] + href;

これ、仕様なんだけど、いろいろ困るんだよな。

Read More>

Aug - 1st

総論賛成だが

Posted at 3:32 pm | Filed Under Javascript

「href=”#” onclick”…”」はそろそろやめよう

周囲には「萌え野郎に説教されたかねえや」という声もあったが、総論では賛成。ただし、アンダーライン入れるとか文字色を変えるとかもしないといけない。社内ではfake_linkクラスをCSSに追加している。

Read More>

Jun - 29th

Tuit: Javascript

Posted at 12:34 pm | Filed Under Javascript, Tuit

IE6でinputタグのname属性を書き換えようとしたらうまく動かない。createElementでname属性を指定できないので困っていたら、こんな情報が:

IE は createElement(’input’) した要素の name 属性を変更することができない。

ではどうすれば良いかと言うと、MSDN にちゃんと書かれている。
var inputElement = document.createElement (’<input type=”text” name=”i_theme” size=”20″>’);

ここ笑う(しかない)所ね。ブラウザ分けするのが面倒だが、IE6 のみの環境なら大丈夫だろう。

いや本当に笑うしかない。こういう失敗データベースはMSDN探すしかないのかな。

Read More>

Jun - 28th

JSLint: eval is evil

Posted at 10:22 pm | Filed Under Javascript

ここのところJavascriptをたくさん書いていて、多分この一ヶ月で書いた量はこれまでの一生に書いた分を越えていると思われるのだが、JSLintの存在を教えてもらった。

こっちはさすがに枯れていて、なるほどと思わせるところもたくさんある。どれも一発で通らなかったのは悲しいが。

しかし一点問題が。JSONの処理用にevalを使っている箇所で

Problem at line 28 character 47: eval is evil.
var res = eval( '(' + xh.responseText + '...

と、身も蓋もないことをいわれてしまう。

追記:「eval is evil」というキーワードで検索してくる人が多いみたいなので追記。JSLintでこのメッセージを出さないようにするには、ページ下部の「Tolerate eval(evalを許容する)」のチェックボックスをオンにしておく。

ちなみにevalについては以下のように説明されている。

eval関数(やFunction、setTimeout、setIntervalなど)を通じてJavaScriptコンパイラへのアクセスが可能になります。JSONのパースには有用ですが、その他のほぼ全ての場合にはコーディングがひどいことになっている証拠です。evalはJavaScriptの中で最も間違って利用されている関数なのです。

JSLintを作った人たちの考え方はこうだから、JSONをパースしている箇所でも無条件に「eval is evil(evalは邪悪です)」と警告される。

Read More>

keep looking »