• 連想配列 hoge[“map”] が使えない理由

    連想配列を作ろうと思い hoge[“map”] = 1 と代入しようとしたらエラーが発生した。
    なぜなんだろうと思い調べたら、下記の記載を見つけた。

    JavaScriptの配列ってmapとかfilterとかあったんだ – phithonの日記

    [“map”]は .mapとしても使えるので、予め配列にはmapメソッドが定義されていたらしい。mapは全ての配列の値に対して計算を行い配列を返すメソッドらしい。こんな便利なものがあったとは知らなかった。

    .filterというのは、ifのような条件式のようだ。これを使うと絞込みをできる。.sortは名前の通りソート。こんな簡単にソートができたなんて驚き。

  • PHPで画面推移なしでファイルをアップロードしてその情報を親ウィンドウの変数に代入する

    そ、そんなことが可能なのか・・・!と自分でもびっくりですが、できました。仕組みは簡単でした。

    Javascript

    function uploadFile() {
        $("#form").submit();    //jQuery
        return false;
    }
    
    window.hoge = [];
    <form id="form" action="/upload" method="post" enctype="multipart/form-data" target="iframe">
    <input name="upload" type="file" onchange="uploadFile();">
    </form>
    <iframe name="iframe"></iframe>Code language: JavaScript (javascript)

    PHP側

    $upload_dir = "/www/var/html/public/";    //ディレクトリはあらかじめ作っておく。Windowsの場合C:\\から
    move_uploaded_file($_FILES['upload']['tmp_name'], $upload_dir . $_FILES['upload']['name']);
    chmod($upload_dir . $_FILES['upload']['name'], 0666);
    parent.window.formdata[0] = "<?php print($_FILES['upload']['name']); ?>";Code language: PHP (php)

    テストはしてないので間違いがあるかもしれません。window.formdataのプロパティとしてグローバル配列変数を作成し、その結果を代入します。ただ、セキュリティの観点からなのかイベントの発火は何度やってもだめでした。親ウィンドウの変数に代入するくらいしかできないようです。

  • IEとそれ以外のブラウザ両方で動くイベント登録

    	//イベント登録
    	if(!Object.addEventListener) {
    		Object.prototype.addEventListener = function(_type, _func, _dummy) {
    				this.attachEvent('on' + _type, _func);
    		};
    	}
    
    Code language: JavaScript (javascript)

    すべてのオブジェクトにaddEventListennerを追加する。jQueryと相性が悪いみたい。