jqueryを使って、新しいウィンドウをpostで開くことを実現します。


ネットワーク上にこの機能の関数があります。純粋なJSで実現します。しかし、プロジェクトでは、この関数はFirefoxと互換できないことが分かりました。この方法を書き直しました。
 
//
var windowDefaultConfig = new Object;
windowDefaultConfig['directories'] = 'no';
windowDefaultConfig['location'] = 'no';
windowDefaultConfig['menubar'] = 'no';
windowDefaultConfig['resizable'] = 'yes';
windowDefaultConfig['scrollbars'] = 'yes';
windowDefaultConfig['status'] = 'no';
windowDefaultConfig['toolbar'] = 'no';
 
/**
* POST JQUERY
@param:url URL
@param:args URL , object
@param:name URL , ,

@param:windowParam
* @author: haijiang.mo
*/
function jQueryOpenPostWindow(url,args,name,windowParam){


//
var _form = $("<form></form>",{
'id':'tempForm',
'method':'post',
'action':url,
'target':name,
'style':'display:none'
}).appendTo($("body"));

//
for(var i in args){
_form.append($("<input>",{'type':'hidden','name':i,'value':args[i]}));
}

//
var windowConfig = clone(windowDefaultConfig);

//
for(var i in windowParam){
windowConfig[i] = windowParam[i];
}

//
var windowConfigStr = "";

for(var i in windowConfig){
windowConfigStr += i+"="+windowConfig[i]+",";
}

//
_form.bind('submit',function(){
window.open("about:blank",name,windowConfigStr);
});

//
_form.trigger("submit");
//
_form.remove();
}
に記録して、後で使えます。