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();
}
に記録して、後で使えます。