例如,假设x = filename.jpg,我想要获取filename,其中filename可以是任何文件名(为了简化,我们假设文件名只包含[a-zA-Z0-9-_])。

我看到x.substring(0, x.indexOf('.jpg'))在DZone片段上,但x.substring(0, x.length-4)不会表现更好吗?因为,length是一个属性,不做字符检查,而indexOf()是一个函数,做字符检查。


当前回答

我不知道这是否是一个有效的选项,但我使用这个:

name = filename.split(".");
// trimming with pop()
name.pop();
// getting the name with join()
name.join('.'); // we split by '.' and we join by '.' to restore other eventual points.

这不仅仅是我知道的一种操作,但至少它应该总是有效的!

更新:如果你想要一个在线,这里你是:

(name.split(“。”)。片(0,1)). join(“。”)

其他回答

接受的答案只删除了最后一个扩展部分(.jpeg),这在大多数情况下可能是一个不错的选择。

我曾经不得不剥离所有扩展名(.tar.gz),文件名被限制为不包含点(所以2015-01-01.backup.tar不会有问题):

var name = "2015-01-01_backup.tar.gz";
name.replace(/(\.[^/.]+)+$/, "");

我们可能会遇到具有多个扩展名后缀的文件名或文件路径。考虑以下方法来修剪它们。

text = "/dir/path/filename.tar.gz"    
output = text.replace(/(\.\w+)+$/,"")

输出结果:"/dir/path/filename"

它解决了文件扩展的问题,特别是当输入有多个扩展名时。

如果你必须处理一个包含完整路径的变量(例如:thePath = "http://stackoverflow.com/directory/subdirectory/filename.jpg"),而你只想返回"filename",你可以使用:

theName = thePath.split("/").slice(-1).join().split(".").shift();

结果将是name == "filename";

要尝试它,请将以下命令写入chrome调试器的控制台窗口: window.location.pathname.split(“/”).slice (1) . join () .split(“。”).shift ()

如果你必须只处理文件名及其扩展名(例如:thenamewitext = "filename.jpg"):

theName = theNameWithExt.split(".").shift();

结果将是name == "filename",与上面相同;

注:

第一个稍微慢一点,因为执行得更多 操作;但在两种情况下都有效,换句话说,它可以提取 没有扩展名的文件名来自一个给定的字符串,该字符串包含一个路径或一个带有ex的文件名。而第二种方法仅适用于给定变量包含一个带有ext的文件名,如filename。Ext,但是稍微快一点。 这两种解决方案都适用于本地和服务器文件;

但我不能说与其他答案的性能比较,也不能说浏览器或操作系统的兼容性。

工作片段1:完整路径 var thePath = "http://stackoverflow.com/directory/subdirectory/filename.jpg"; name = thePath.split(“/”).slice (1) . join () .split(“。”).shift (); 警报(name);

工作片段2:具有扩展名的文件名 var thenamewiext = "filename.jpg"; name = theNameWithExt.split(“/”).slice (1) . join () .split(“。”).shift (); 警报(name);

工作代码段2:具有双扩展名的文件名 var thenamewiext = "filename.tar.gz"; name = theNameWithExt.split(“/”).slice (1) . join () .split(“。”).shift (); 警报(name);

我喜欢用正则表达式来做。它很短,很容易理解。

(const regexppattern of [] / \ . .+$/, //查找第一个圆点及其后面的所有内容。 / \[^ /。+$/ //获取最后一个圆点及其后面的所有内容。 ) { console.log(“myFont.ttf”。替换(regexPattern”、“)) console.log(“myFont.ttf.log”。替换(regexPattern”、“)) } / *输出 myFont myFont myFont myFont.ttf * /

上述解释可能不是很严谨。如果您想获得更准确的解释,可以访问regex101进行检查

美元\ . . + \[^ /。]。+美元

var fileName = "something.extension";
fileName.slice(0, -path.extname(fileName).length) // === "something"