1

我需要有关如何使用 JavaScript 确定文件类型的帮助。例如在这个 html 中。

<div class="indi-download">
<div class="pull-left">
    <h6 class="file-format">%file_display_name%</h6>
</div>
<div class="pull-right">
    <a class="download-link" href="%file_url%">Download</a>
</div>

在这行代码上,

<a class="download-link" href="%file_url%">Download</a>

href="%file_url%" 将返回具有以下扩展名的文件类型:例如:.docx 或 .pdf。

像这样的东西。

<a class="download-link" href="http://mysite.com/download/myfiles/sample.pdf">Download</a>

我的问题是,我需要检测使用 javascript 的文件类型。如果是 .pdf,则 class class="file-format" 将变为 class="pdf-file-format" 和 class="doc-file-format" 用于 .doc。这取决于文件扩展名。关于如何做到这一点的任何想法?这样做的最佳技巧是什么?

这是我的示例输出,我只想更改文件的图标,这就是我需要更改类名的原因。

在此处输入图像描述

编辑 我做了这样的事情,但如果列表中有多个项目,它就不起作用。它仅适用于第一项。请帮我。

<body onload="myFunction()">
<div class="indi-download">
<div class="pull-left">
    <h6 class="pdf-file" id="file-display-id">%file_display_name%</h6>
</div>
<div class="pull-right">
    <a class="download-link" id="download_link" href="%file_url%">Download</a>
</div>
</div>
</body>

JavaScript

<head>
<script type="text/javascript">
function myFunction()
 {
  var url = document.getElementById("download_link").href;
 var ext = url.split('.').pop();
 if(ext=='pdf'){
 var newfileclass = document.getElementById("file-display-id");
 newfileclass.className="pdf-file";
 }
 else if((ext=='docx')){
 var newfileclass = document.getElementById("file-display-id");
 newfileclass.className="pdf-file doc-file";
}
else if(ext=='zip'){
var newfileclass = document.getElementById("file-display-id");
newfileclass.className="pdf-file zip-file";
}
else{
var newfileclass = document.getElementById("file-display-id");
newfileclass.className="other-file";
}
}
</script> 
</head>
4

3 回答 3

0

如果您的所有文件都有扩展名,只需拆分文件名extension = filename.split('.');并通过扩展名确定文件类型。

这个怎么样:

function changeClass(fileUrl){
    var extension = fileUrl.split('.').pop();
    if(extension.toLowerCase() == 'pdf')
    {
        return "pdf-file-format";
    }

}

$(document).ready(function(){
    $(a).live().addClass(changeClass( $(a).attr('href') ) );
});

这是一种伪代码,我还没有测试过,但我想你明白我的意思;)

也正如 Lakshmi 所说:如何使用 jquery 或 javascript 获取文件的扩展名?

于 2013-10-31T07:31:10.103 回答
0

课程必须是“pdf文件格式”吗?我直接通过 CSS 在我自己的网站上检测到 .pdf 文件链接,例如

a[href$="pdf"] { /* css styles for pdf links */ }

诶?

于 2013-10-31T07:38:55.877 回答
0

给标签一个id

<a class="download-link" id="download_link" href="http://mysite.com/download/myfiles/sample.pdf">Download</a>

并使用这个javascript函数来改变类

var change_class_a = function(url) {
    var m = url.match(/(.*)[\/\\]([^\/\\]+)\.(\w+)$/);
    if(m[3] == 'pdf')
       document.getElementById("download_link").className = "YOUR_CLASS";

};

var url = document.getElementById("download_link").href;
change_class_a(url); 
于 2013-10-31T07:40:20.380 回答