我想显示后10个字符,直到.pdf或xlx或.docx匹配。每个结果都有链接。当用户单击垂直链接时,它将重定向到匹配的文件,并且将下载文件。谁能帮助我。
function createRowMultiresult(jobjects) {
var $div = $('<div class="chat Bot"></div>');
var $div2 = $('<div class="user-photo"><img src="{% static "Robot.jpg" %}" /></div>');
$div.append($div2);
var $tbl = $('<table style="width:100%;"></table>');
if (jobjects.length>1){
var $tr = $('<tr><td style="padding:5px;">Multiple results Found for your query. Please search with specific keyword</td></tr>');
$tbl.append($tr);
}
for(var x=0; x<jobjects.length;x++){
var currentobj = jobjects[x];
if (currentobj.ans != null){
if (currentobj.ans.indexOf("/AA") != -1){
var $tr = $('<tr><td style="padding:5px;"><a href="https://' + currentobj.ans +'" target="_blank" >Click Here for User Guide</a></td></tr>');
$tbl.append($tr);
}
else{
var $tr = $('<tr><td style="padding:5px;">' +(x+1)+'.'+ currentobj.ans.replace(/[^\w\s]/gi, "<br/>") +'</td> </tr>');
$tbl.append($tr);
if (currentobj.Pic.length>7){
var $tr = $("<tr><td style='text-align:center;'><img class='productpic' src='{% static '/Pictures/' %}" + currentobj.Pic +"' /></td></tr>");
$tbl.append($tr);
}
}
}
else if(currentobj.filename != null){
alert("Got there");
var $tr = $('<tr><td style="padding:5px;"><a href="https://' + currentobj.ans + '" target="_blank" >' + currentobj.filename.slice(0,10)+"...."+ +'</a></td> </tr>');
$tbl.append($tr);
}
}
var $par = $('<p class="chat-message"></p>');
$par.append($tbl);
$div.append($par);
$chatlog.append($div);
}
每个结果都有链接。
示例实际结果:
预期的输出,当用户单击它时将下载:
答案 0 :(得分:1)
您可以简单地计算字符长度,并在某个点之后替换为'...'。
var displayName = ( currentobj.ans.length > 10 ) > ( currentobj.ans.substring( 0, 10 ) + '...' ) : currentobj.ans;
现在,您可以使用此displayName
变量进行显示了。
在.substring()
函数中,第一个参数是起点,第二个参数是终点。
答案 1 :(得分:0)
根据样本和预期的输出,最简单的方法是使用替换函数,即
result_str.replace(/_data_data\./, '...')
答案 2 :(得分:0)
您可以将正则表达式与捕获组一起使用。 $ n是第n个组。
var regex = /(\w{10})\w+(\.\w+)/;
var str = "insert_data_data_data.pdf";
console.log(str.replace(regex, "$1...$2"));