a标签下载;页面传参row对象先转换成字符串。

时间:2023-03-09 00:22:09
a标签下载;页面传参row对象先转换成字符串。

jsp:添加一列

<th data-options="field:'id',width:180,formatter: rowformater" width="20%">下载文件</th>

js:

function rowformater(value,row,index)
{
return "<a href='"+row.picUrl+"' target='_blank'>下载</a>";
}

a标签下载;页面传参row对象先转换成字符串。

但是这样子word等文件是可以下载的,但是图片会直接打开。

于是,还是调用上次的写在jsp里面的java代码,但是一直开始一直传不过去row的值,起初以为是自己的字符串拼接不对,单双引号不对,但是后来去问同事时发现是对象无法传递的,必须转换成字符串。

如果一定要将整个对象进行传递,就要JSON.stringify(row),再转换回来,JSON.parse(jsonstr)。但是是几个参数,就直接取出来就好了,而且将参数加上\"表示单引号转换为字符串。

function rowformater(value,row,index)
{
/*"download.htm?filePath=" + row.picUrl + "&filename="+row.picName;
href='JavaScript:;' onclick='myClick(this.id)' 
onmouseover="show(this.id)" onmouseout="hide(this.id)"*/
//var para = JSON.stringify(row); 
//para = para.replace(/"/g,'\\"');
return "<a href='JavaScript:' onclick='clickDown(\""+row.picUrl+"\",\""+row.picName+"\")' target='_blank'>下载</a>";
}

function clickDown(picUrl,picName){
debugger
window.location.href = "download.htm?filePath=" + picUrl + "&filename="+picName;
}