2008/12/09(火)自作ライブラリのメモ
ポップアップ
var popup = new CPopup(); popup.append(項目名, イベント, オプション); popup.append(CPopup.Separator); popup.append(項目名, イベント, オプション); popup.show();
引数の例
- イベント
- {'click':clickentry}
- オプション
- {n:a[1], w:s._self}
イベントリスト
イベント名 | 概要 |
click | 項目がクリックされたときに呼び出される. 返値をfalseにするとpopupを閉じない |
close | 未実装。popupが閉じられる直前に呼び出される |
closed | 未実装。popupが閉じられた直後に呼び出される |
イベントメソッドの例
function clickentry(イベント, ポップアップ本体, 項目名, オプション){ }
2008/12/02(火)WebAPI
最近はユーザ登録必要なサービスばかりなのね
お試しで作りたいだけなんだけどなぁ
機能限定でいいからguestで2-3日使わせてもらえないかなぁ
2008/11/21(金)length プロパティ
配列の要素数ではなく,インデックスの最大値+1を指す.
そのため,
var a = new Array(); a[0] = 0; // length -> 1 a[1] = 1; // length -> 2 a[100] = 100; // length -> 101 a[2] = 2; // length -> 101
になる...
要素数を知りたい場合カウントするしかないの?
var count = 0; for(var i in ary){ count++; }
2008/11/20(木)メソッド定義のマイルール
コンストラクタの定義
class = function(o){ }
プロトタイプで定義
ここに定義するのは,オブジェクト名付きで呼び出されるメソッド類.thisを信用することができるもの.class内部からしか呼び出さないものは_を付ける.(_付きのメソッドを外部から呼び出しても動作は保証しない)
class.prototype = { func1: function(){ }, _func2: function(){ } }
クラス名付きで定義
イベントなどにより呼び出されるメソッド類.thisを信用できない.必要ならば,引数に自分自身を指すオブジェクトを入れる.
class.func3 = function(){ }
2008/11/19(水)javascriptのpro...
前と同じ罠にはまってしまった...
なにやってるんだか.
A = function(){} A.prototype = { pos: {x:0, y:0} } a = new A(); b = new A(); a.pos.x = 10; a.pos.y = 20; b.pos.x = 30; b.pos.y = 40; a.pos.x; // -> 30; a.pos.y; // -> 40; b.pos.x; // -> 30; b.pos.y; // -> 40;
正しくは↓の通り。
A = function(){ this.pos = {x:0, y:0}; } A.prototype = { pos: null } a = new A(); b = new A(); a.pos.x = 10; a.pos.y = 20; b.pos.x = 30; b.pos.y = 40; a.pos.x; // -> 10; a.pos.y; // -> 20; b.pos.x; // -> 30; b.pos.y; // -> 40;
一度,以前作ったプログラムも見直した方がいいかもしれない
2008/11/06(木)javascriptのprototypeではまった
微妙にはまった罠
A = function(){} A.prototype = { data: new Array(), push: function(a){ this.data.push(a); }, pop: function(){ return this.data.pop(); } } a = new A(); b = new A(); a.push('1st'); a.push('2nd'); b.push('3rd'); a.pop(); // -> '3rd' b.pop(); // -> '2nd' a.pop(); // -> '1st'
当然と言えば当然だけど、ポインタ的なものが見えにくいので原因がわかるまで時間がかかりました。というか、C++のクラスとJavascriptのプロトタイプの違いがわかった気がする。正しくは↓の通り。
A = function(){ this.data = new Array(); } A.prototype = { data: null, push: function(a){ this.data.push(a); }, pop: function(){ return this.data.pop(); } } a = new A(); b = new A(); a.push('1st'); a.push('2nd'); b.push('3rd'); a.pop(); // -> '2nd' b.pop(); // -> '3rd' a.pop(); // -> '1st'
オブジェクトを生成するたびに data そのものを正しく初期化する必要あり。
2008/09/09(火)IEとFFの互換性を維持するために
片方にあったり無かったりするメソッドやプロパティを何とかするためのメモ。
無い場合はundefinedとか返されるので || で繋いでしまえばなんとかなることが多い。
メモ書きなので間違えてるかも。
でも、
x = obj.yyy || obj.zzz;
って書く分には逆でも問題なかったりする。
そのうちいろいろ追加したりすると思う。
プロパティまわり
IE | FF | 用途 |
---|---|---|
innerText | textContent | エレメントの中のテキストのみ取り出す |
e.srcElement | e.target | イベントの発生元 |
tagName | localName | タグの名前(AとかIMGとか)* |
obj.currentStyle | document.defaultView.getComputedStyle(obj, '') | 実際に表示されているスタイル |
clientHeight | offsetHeight | エレメントの高さ |
clientWidth | offsetWidth | エレメントの幅 |
* Safari, Google ChromeはlocalNameは小文字で、tagNameは大文字で返すっぽい
イベントまわり
デフォルトの動作を止める
_preventDefault = function (ev){ if(IsIE) ev.returnValue = false; else ev.preventDefault(); }
これ以上次の要素にイベントを送らない
但し、IEとFFではイベントの発生順が逆なので注意
_stopPropagation = function (ev){ if(ADIARY.IsIE) ev.cancelBubble = true; else ev.stopPropagation(); }
エレメントのイベントにメソッドを割り当てる
クリックとかいろいろ。
但し、無名関数を登録すると取り除けなくなるので注意*1
addEvent = function (target, name, func) { if(target == undefined || name == '' || func == undefined) return; if(target.addEventListener) target.addEventListener(name, func, false); else if(target.attachEvent) target.attachEvent('on'+name, func); else return false;// setAttribute('on'+name, func); return true; }
エレメントのイベントからメソッドを取り除く
上のaddEventで追加したやつ限定
delEvent = function (target, name, func) { if(target == undefined || name == '' || func == undefined) return; if(target.removeEventListener) target.removeEventListener(name, func, false); else if(target.detachEvent) target.detachEvent) ('on'+name, func); else return false;// setAttribute('on'+name, ''); return true; }
2008/08/29(金)ajax
せりかのアルバムで利用しようかと思い、試行錯誤中。
ファイルの移動や、リネームあたりを実装してみたいなぁ。
現在通信する部分を一通りライブラリ化。
あと、一部のよく使いそうなあたりもメソッド化。
prototype.jsとかYUIとか使えば簡単なんだろうけど、そこまででかいライブラリ入れても仕方ないし。
以下、現在の実装例のメモ
2008/08/27(水)[C++] 久しぶりだ
ここしばらくPHPとかJavaScriptとかPerlとかばかりだったのでなんかいろいろ忘れてる
で、一番戸惑ったのが変数の型。
以前は型があってこそプログラムという感じがしていたのに、逆に鬱陶しくなってきた。
探せば型に囚われない変数を扱うライブラリとかありそうだけど、リハビリも込めて自前でclassを書いてみることにした。
とりあえず目標は
var a;
a = "10";
a += 3.5;
cout << a; // 13.5
になるようにしたいところ
作ったけど
なんかいまいちなので無かったことにした。
2008/07/21(月)日付関数 mktime
mktime
int mktime ([ int $hour [, int $minute [, int $second [, int $month [, int $day [, int $year [, int $is_dst ]]]]]]] )
指定した時間とかでUNIX時間を作る.
それぞれのパラメータには,負の数や本来の値を超えた数値を指定することができる.
その場合,適切に日付は変換されるため,特定の日付からの相対日を作ることができる.
mktime(0, 0, 0, 7, -1); // 6/30のこと
mktime(0, 1600, 0, 7, 1); // 1600min -> 26[hour] 40[min]なので 7/2 2:40のこと
以下検索用
[php] [getdate] [mktime] [日付]