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

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


当前回答

不知道哪个会执行得更快,但当涉及到。jpeg或。html等扩展名时,这将更可靠

x.replace(/\.[^/.]+$/, "")

其他回答

这就是正则表达式派上用场的地方!Javascript的.replace()方法将接受一个正则表达式,你可以利用它来完成你想要的:

// assuming var x = filename.jpg or some extension
x = x.replace(/(.*)\.[^.]+$/, "$1");
name.split('.').slice(0, -1).join('.')

这就是所有的享受你的编码…

X.length-4只支持3个字符的扩展。如果有filename。jpeg或filename。pl呢?

编辑:

回答……当然,如果您总是使用.jpg扩展名,x.length-4就可以了。

但是,如果您不知道扩展的长度,那么许多解决方案中的任何一个都更好/更健壮。

x = x.replace(/\..+ $ / ');

OR

x = x.substring(0, x. lastindexof ('.'));

OR

X = X .replace(/(.*)\.(.*?)$/, "$1");

OR(假设文件名只有一个点)

parts = x.match(/[^\.]+/);
x = parts[0];

OR(也是只有一个点)

parts = x.split(".");
x = parts[0];

如果你使用的是Node.js,一个简单的答案就是第一条注释。 我的任务是我需要从Node服务器中删除Cloudinary中的一个图像,我只需要获得图像名称。 例子:

const path = require("path")
const image=xyz.jpg;
const img= path.parse(image).name
console.log(img) // xyz

这是我用来从文件名中删除扩展名的代码,不使用regex或indexOf (indexOf在IE8中不支持)。它假定扩展名是最后一个'之后的任何文本。'字符。

它适用于:

没有扩展名的文件:"myletter" 使用'文件。"my.letter.txt" 未知文件扩展名长度:"my.letter.html"

代码如下:

var filename = "my.letter.txt" // some filename

var substrings = filename.split('.'); // split the string at '.'
if (substrings.length == 1)
{
  return filename; // there was no file extension, file was something like 'myfile'
}
else
{
  var ext = substrings.pop(); // remove the last element
  var name = substrings.join(""); // rejoin the remaining elements without separator
  name = ([name, ext]).join("."); // readd the extension
  return name;
}