例如,假设x = filename.jpg,我想要获取filename,其中filename可以是任何文件名(为了简化,我们假设文件名只包含[a-zA-Z0-9-_])。
我看到x.substring(0, x.indexOf('.jpg'))在DZone片段上,但x.substring(0, x.length-4)不会表现更好吗?因为,length是一个属性,不做字符检查,而indexOf()是一个函数,做字符检查。
例如,假设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.split('.').slice(0, -1).join('.')
这就是所有的享受你的编码…
其他回答
我喜欢用正则表达式来做。它很短,很容易理解。
(const regexppattern of [] / \ . .+$/, //查找第一个圆点及其后面的所有内容。 / \[^ /。+$/ //获取最后一个圆点及其后面的所有内容。 ) { console.log(“myFont.ttf”。替换(regexPattern”、“)) console.log(“myFont.ttf.log”。替换(regexPattern”、“)) } / *输出 myFont myFont myFont myFont.ttf * /
上述解释可能不是很严谨。如果您想获得更准确的解释,可以访问regex101进行检查
美元\ . . + \[^ /。]。+美元
这是我用来从文件名中删除扩展名的代码,不使用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;
}
我将使用类似x.substring(0, x.lastIndexOf('.'))的东西。如果你追求的是性能,那就不要用javascript:-p不,多一条语句对于99.99999%的目的来说真的没什么关系。
我喜欢这篇文章,因为它只有一行字,读起来不难:
filename.substring(0, filename.lastIndexOf('.')) || filename
我不知道这是否是一个有效的选项,但我使用这个:
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(“。”)