js获取文件名或文件后缀名(扩展名)的几种方法

2024-02-04 20:28

本文主要是介绍js获取文件名或文件后缀名(扩展名)的几种方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

有时候我们需要通过含有文件名和后缀名的一个字符串中提取出该文件的文件名或文件后缀名(扩展名),可以通过如下几种方式进行截取。

例如文件名为: var fileName="12345.txt";

方式一:subtring()

用法参考博文 【js截取字符串subString()方法】 js截取字符串subString()方法_js 如何使用substring()截取字符串?-CSDN博客

使用subtring() 截取字符串,对于文件名中会出现多个点的很有用,从最后一个点的地方截取。

源代码

var fileName="12345.txt";// 获取后缀名和点
var suffix = fileName.substring(fileName.lastIndexOf("."));//.txt
console.log(suffix)// 只获取后缀名
var suffixName = fileName.substring(fileName.lastIndexOf(".")+1);//txt
console.log(suffixName)// 获取文件名
var name = fileName.substring(0, fileName.lastIndexOf("."));//12345
console.log(name)

运行结果

方式二:substr()

同subtring()的字符串截取

源代码

var fileName="12345.txt";// 获取后缀名和点
var suffix = fileName.substr(fileName.lastIndexOf("."));//.txt
console.log(suffix)// 只获取后缀名
var suffixName = fileName.substr(fileName.lastIndexOf(".")+1);//txt
console.log(suffixName)// 获取文件名
var name = fileName.substr(0, fileName.lastIndexOf("."));//12345
console.log(name)

运行结果

方式三:正则

使用正则,对只会出现一个点的适用:

源代码

var fileName="12345.txt";// 获取后缀名和点
var suffix = fileName.match(/.[^.]+$/)[0];//.txt
console.log(suffix)// 只获取后缀名
var suffixName = fileName.match(/[^.]+$/)[0];//txt
console.log(suffixName)// 获取文件名
var name = fileName.match(/^[^.]+/)[0];//12345
console.log(name)

运行结果

当文件名中出现2个点的情况下,会出现异常

源代码

var fileName="12345.txt.zip";// 获取后缀名和点
var suffix = fileName.match(/.[^.]+$/)[0];//.zip
console.log(suffix)// 只获取后缀名
var suffixName = fileName.match(/[^.]+$/)[0];//zip
console.log(suffixName)// 获取文件名
var name = fileName.match(/^[^.]+/)[0];//12345
console.log(name)

运行结果

方式四:转数组

数组方法可以参考博文 【js数组和字符串之间的转换方式以及数组的一些方法】: js数组和字符串之间的转换方式以及数组的一些方法-CSDN博客

对只会出现一个点的适用:

源代码

var fileName="12345.txt";// 获取后缀名和点
var suffix = '.'+fileName.split('.').pop();//.txt
console.log(suffix)// 只获取后缀名
var suffixName = fileName.split('.').pop();//txt
console.log(suffixName)// 获取文件名
var name = fileName.split('.').shift();//12345
console.log(name)

运行结果

当文件名中出现2个点的情况下,会出现异常

源代码

var fileName="12345.txt.zip";// 获取后缀名和点
var suffix = '.'+fileName.split('.').pop();//.zip
console.log(suffix)// 只获取后缀名
var suffixName = fileName.split('.').pop();//zip
console.log(suffixName)// 获取文件名
var name = fileName.split('.').shift();//12345
console.log(name)

运行结果

这篇关于js获取文件名或文件后缀名(扩展名)的几种方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/678701

相关文章

Springboot控制反转与Bean对象的方法

《Springboot控制反转与Bean对象的方法》文章介绍了SpringBoot中的控制反转(IoC)概念,描述了IoC容器如何管理Bean的生命周期和依赖关系,它详细讲解了Bean的注册过程,包括... 目录1 控制反转1.1 什么是控制反转1.2 SpringBoot中的控制反转2 Ioc容器对Bea

C++实现回文串判断的两种高效方法

《C++实现回文串判断的两种高效方法》文章介绍了两种判断回文串的方法:解法一通过创建新字符串来处理,解法二在原字符串上直接筛选判断,两种方法都使用了双指针法,文中通过代码示例讲解的非常详细,需要的朋友... 目录一、问题描述示例二、解法一:将字母数字连接到新的 string思路代码实现代码解释复杂度分析三、

mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespace id不一致处理

《mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespaceid不一致处理》文章描述了公司服务器断电后数据库故障的过程,作者通过查看错误日志、重新初始化数据目录、恢复备... 周末突然接到一位一年多没联系的妹妹打来电话,“刘哥,快来救救我”,我脑海瞬间冒出妙瓦底,电信火苲马扁.

golang获取prometheus数据(prometheus/client_golang包)

《golang获取prometheus数据(prometheus/client_golang包)》本文主要介绍了使用Go语言的prometheus/client_golang包来获取Prometheu... 目录1. 创建链接1.1 语法1.2 完整示例2. 简单查询2.1 语法2.2 完整示例3. 范围值

SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)

《SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)》本文介绍了如何在SpringBoot项目中使用Jasypt对application.yml文件中的敏感信息(如数... 目录SpringBoot使用Jasypt对YML文件配置内容进行加密(例:数据库密码加密)前言一、J

Spring Boot 中正确地在异步线程中使用 HttpServletRequest的方法

《SpringBoot中正确地在异步线程中使用HttpServletRequest的方法》文章讨论了在SpringBoot中如何在异步线程中正确使用HttpServletRequest的问题,... 目录前言一、问题的来源:为什么异步线程中无法访问 HttpServletRequest?1. 请求上下文与线

解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题

《解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题》在Spring开发中,@Autowired注解常用于实现依赖注入,它可以应用于类的属性、构造器或setter方法上,然... 目录1. 为什么 @Autowired 在属性上被警告?1.1 隐式依赖注入1.2 IDE 的警告:

SpringBoot快速接入OpenAI大模型的方法(JDK8)

《SpringBoot快速接入OpenAI大模型的方法(JDK8)》本文介绍了如何使用AI4J快速接入OpenAI大模型,并展示了如何实现流式与非流式的输出,以及对函数调用的使用,AI4J支持JDK8... 目录使用AI4J快速接入OpenAI大模型介绍AI4J-github快速使用创建SpringBoot

javaScript在表单提交时获取表单数据的示例代码

《javaScript在表单提交时获取表单数据的示例代码》本文介绍了五种在JavaScript中获取表单数据的方法:使用FormData对象、手动提取表单数据、使用querySelector获取单个字... 方法 1:使用 FormData 对象FormData 是一个方便的内置对象,用于获取表单中的键值

Node.js net模块的使用示例

《Node.jsnet模块的使用示例》本文主要介绍了Node.jsnet模块的使用示例,net模块支持TCP通信,处理TCP连接和数据传输,具有一定的参考价值,感兴趣的可以了解一下... 目录简介引入 net 模块核心概念TCP (传输控制协议)Socket服务器TCP 服务器创建基本服务器服务器配置选项服