下面一种方法百度出来的,试了下发现不行
// 3.1)首先在react组件的render函数里面建立一个隐藏的div ,例如:
<div id='downloadDiv' style={{display:'none'}}></div>
//3.2 ) 用户在页面上触发下载按钮后,执行以下函数:在隐藏的div里面创建临时表单,获取表单,提交表单,在div节点卸载临时表单。
downloadDetailData=()=>{
var divElement= document.getElementById("downloadDiv");
var downloadUrl=`${apiBasePath}/api/xxxxx/downloadDetailData`;
var params=JSON.stringify({
key:'value'
})
ReactDOM.render(
<form action={downloadUrl} method="post">
<input name="params" type="text" value={params}/>
</form>,
divElement
)
ReactDOM.findDOMNode(divElement).querySelector('form').submit();
ReactDOM.unmountComponentAtNode(divElement);
}