例如,假设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()是一个函数,做字符检查。
当前回答
这就是正则表达式派上用场的地方!Javascript的.replace()方法将接受一个正则表达式,你可以利用它来完成你想要的:
// assuming var x = filename.jpg or some extension
x = x.replace(/(.*)\.[^.]+$/, "$1");
其他回答
Node.js从全路径保存目录中删除扩展
例如https://stackoverflow.com/a/31615711/895245做了path/hello.html -> hello,但如果你想要path/hello.html -> path/hello,你可以使用这个:
#!/usr/bin/env node
const path = require('path');
const filename = 'path/hello.html';
const filename_parsed = path.parse(filename);
console.log(path.join(filename_parsed.dir, filename_parsed.name));
输出目录以及:
path/hello
https://stackoverflow.com/a/36099196/895245也实现了这一点,但我发现这种方法在语义上更讨人喜欢。
在Node.js v10.15.2中测试。
不知道哪个会执行得更快,但当涉及到。jpeg或。html等扩展名时,这将更可靠
x.replace(/\.[^/.]+$/, "")
name.split('.').slice(0, -1).join('.')
这就是所有的享受你的编码…
如果你使用的是Node.js,一个简单的答案就是第一条注释。 我的任务是我需要从Node服务器中删除Cloudinary中的一个图像,我只需要获得图像名称。 例子:
const path = require("path")
const image=xyz.jpg;
const img= path.parse(image).name
console.log(img) // xyz
var fileName = "something.extension";
fileName.slice(0, -path.extname(fileName).length) // === "something"