javascript基础系列:字符串的常用方法

冷不防 2022-11-20 02:59 312阅读 0赞

字符串的常用方法

所有用的单引号、双引号、反引号包起来的都是字符串

1. charAt/charCodeAt

charAt:根据索引获取指定位置的字符
charCodeAt: 获取指定字符的ASCII码值(UNicode编码值)
@params
n[number] 获取字符指定的索引
@return
返回查找到的字符(找不到返回的是空字符串不是undefined,或者对应的编码值)

  1. let str = 'zhufengpeiixunyangfangqihang';
  2. console.log(str.charrAt(0)) // => Z

2. ‘substr/substring/slice’

实现字符串截取
substr(n, m): 从索引n开始截取m个字符串,m不写截取到末尾
substring(n, m): 从索引n开始找到索引m处(不含m),超过索引的也只截取到末尾,不支持负索引
slice(n,m):和substriing一样,都是找到索引为m处,但是slice可以支持负数作为索引,其余两个方法是不可以的

  1. let str = 'lanfengqiuqiu'
  2. console.log(str.substr(3,2))
  3. console.log(str.substring(3,5))

3. indexOf/lastIndexOf/includes()

验证字符是否存在
indexOf(n,m):获取n第一次出现位置的索引,m是控制查找的起始位置索引
lastIndexOf(x):最后一次出现位置的索引
没有这个字符,返回结果是-1

  1. let str = 'lanfengqiuqiu'
  2. console.log(str.indexOf('n')) // 验证第一次出现的位置,返回的索引
  3. console.log(str.lastIndexOf('n'))
  4. if(!str.includes('@')) {
  5. console.log('当前字符串不包含@')
  6. }

4. toUpperCase/toLowerCase

字符串中字母大小写转换
toUpperCase():转大写
toLowerCase():转小写

5. split

split([分隔符]):把字符串按照指定的分隔符拆分成数组(和数组中的join相对应)
split方法支持传递正则表达式

  1. //把|分隔符变成为,分隔符
  2. let str = 'music|movie|eat|sport'
  3. let arr = str.split('|')
  4. console.log(arr)
  5. arr.join()

6. replace

replace(新字符,老字符):实现字符串的替换(经常伴随着正则而用)

  1. let str='岚枫@秋秋@前端'
  2. str = str.replace('@', '-') //在不使用正则表达式的情况下
  3. console.log(str) // 岚枫-秋秋@前端
  4. // -----
  5. let str='岚枫@秋秋@前端'
  6. str = str.replace(/@/g, '-') //在不使用正则表达式的情况下
  7. console.log(str) // 岚枫-秋秋@前端

7. match

localCompare
trim/trimLeft/trimRight
控制台输出String.prototype查看所有字符串中提供的方法

实现一些常用的需求

1. 时间字符串的格式化处理

  1. // 方案一:用replace
  2. let time = '2019-7-24 12:6:23'
  3. // 变为自己需要呈现的格式
  4. // “2019年07月24日 12时06分23秒”
  5. time.replace('-', '年').replace('-','月').replace('', ‘日’)
  6. .replace(':', ‘时’).replace(':', '分') + ‘秒’;
  7. console.log(time)
  8. // 方案二
  9. let addZero = val => val.length < 2 ? '0' + val : val
  10. let time = '2019-7-24 12:6:23'
  11. let ary = time.split(/(?: |-|:)/g)
  12. time = ary[0]+ '年'+ addZero(ary[1]) + '月' + addZero(ary[2]) + '日'

2. 实现一个方法 queryUrlParams获取一个URL地址问号后面传递的参数信息

  1. let url = 'http://www.baidu.com?lx=1&name=lanfeng&teacher=aaa#box'
  2. /** lx: 1, name:'lanfeng', teacher: 'aaa', hash: 'box' **/
  3. //1. 获取问号后面的值
  4. let askIndex = url.indexOf('?')
  5. let wellIndex = url.indexOf('#')
  6. let askText = url.substring(askIndex+1,wellIndex)
  7. let wellText = url.substring(wellIndex+1)
  8. console.log(askText, wellText)
  9. //2.问号后面的值详细处理
  10. let result = { };
  11. let askAry = askText.split('&');
  12. console.log(askAry)
  13. askAry.forEach(item => {
  14. let n = item.split('=')
  15. result[n[0]] = n[1]
  16. })
  17. result['hash']= wellText
  18. //-----
  19. /** *queryURLParams: 获取URL地址中问号传参的信息和哈希值 * @params url[string]要解析的url字符串 * @return [object]包含参数和哈希值信息的对象 **/
  20. function queryURLParams(url) {
  21. let askIn = url.indexOf('?');
  22. let wellIn = url.indexOf('#');
  23. let askText = ''
  24. let wellText = ''
  25. wellIn === -1 ? wellIn = url.length : null
  26. askIn >=0 ? askText = url.substring(askIn+1 , wellIn) : null
  27. wellText = url.substring(wellIn+1)
  28. // 获取每一部分信息
  29. let result = { }
  30. wellText !== '' ? result['hash'] = wellText : null
  31. if(askText !== '') {
  32. let ary = askText.split('&');
  33. ary.forEach(item => {
  34. let itemAry = item.split('=')
  35. result[itemAry[0]] = itemAry[1]
  36. })
  37. }
  38. return result
  39. }
  40. let url = 'http://www.baidu.com?lx=1&name=lanfeng&teacher=aaa#box'
  41. let paramsObj = queryURLParams(url)
  42. console.log(paramsObj)

3. 日期对象的基本操作

  1. 获取当前客户端(本地电脑)本地的时间

    / 获取当前客户端(本地电脑)本地的时间 这个时间用户是可以自己修改的,所以不能作为重要的参考依据 Thu Sep 10 2020 09:09:50 GMT+0800 (中国标准时间) 获取的结果不是字符串是对象数据类型的,属于日期对象(或者说是Date这个类的实例对象) /
    let time = new Date()

  2. 标准日期对象中提供了一些属性和方法,供我们操作日期信息

    • getFullYear()获取年
    • getMonth() 获取月
    • getDate() 获取日
    • getDay() 获取日期
    • getHours() 获取时
    • getMinutes() 获取分
    • getSeconds() 获取秒
    • getMilliseconds() 获取毫秒
    • getTime() 获取当前日期距离1970/1/1 00:00:00 这个日期之间的毫秒差
    • timetoLocaleDateString() 获取年月日(字符串)
    • timetoLocaleString() 获取完整的日期字符串

    / queryDate:获取当前的日期,把其转换喂想要的格式 @params * @return /
    function queryDate() {
    // 1. 获取当前日期及详细信息

    1. let time = new Date(),
    2. year = time.getFullYear(),
    3. month = time.getMonth() + 1
    4. day = time.getDate(),
    5. week = time.getDay(),
    6. hours = time.getHours(),
    7. minutes = time.getMinutes(),
    8. seconds = time.getSeconds();

    // 2. 拼凑成我们想要的字符串
    let weekAry = [‘日’, ‘一’, ‘二’, ‘三’, ‘四’, ‘五’, ‘六’]
    let result = year + “年” + addZero(month) + “月” + addZero(day) + “日”
    result += “星期” + weekAry[week] + “ “

    result += addZero(hours)+ “:” + addZero(minutes) + “:” + addZero(seconds);

    }

    / addZero:不足十补0 @params * @return 处理后的结果(不足十位的补充零) /
    function addZero(val) {

    1. val = Number(val);

    return val < 10 ? ‘0’ + val : val
    }

  3. new Date() 除了获取本机时间,还可以把一个时间格式字符串转化为标准的时间格式

    new Date(“2019/7/26”) // Fri Jul 26 2019 00:00:00 GMT+0800 (中国标准时间)
    //
    / 支持的格式 yyyy/mm/dd * yyyy-mm-dd 这种格式在ie下不支持 /

  1. // ------
  2. let time = '2019-5-30 12:0:0'
  3. // => "2019年-5月30日 12:0:0"
  4. /** * 字符串处理解决方法 **/
  5. function formatTime(time) {
  6. // 1. 先获取年月日信息
  7. let ary = time.split(''),
  8. aryLeft = ary[0].split('-'),
  9. aryRight = ary[1].split(':');
  10. ary = aryLeft.concat(aryRight)
  11. // 2. 拼接成为我们想用的格式
  12. let result = ary[0] + '年'+ addZero(ary[1]) + '月' + addZero(ary[2]) + '日';
  13. result += ' ' + addZero(ary[3]) + ':' + addZero(ary[4]) + ':' + addZero(ary[5])
  14. }
  15. formatTime(time)
  16. /** * addZero:不足十补0 * @params * @return 处理后的结果(不足十位的补充零) **/
  17. function addZero(val) {
  18. val = Number(val);
  19. return val < 10 ? '0' + val : val
  20. }
  21. /** * 基于日期对象处理 **/
  22. function formatTime2(time) {
  23. // 1. 把时间字符串转换为标准日期对象
  24. time = time.replace(/-/g, '/')
  25. time = new Date(time)
  26. //2. 基于方法获取年月日等信息
  27. let year = time.getFullYear(),
  28. month = addZero(time.getMonth() + 1),
  29. day = addZero(time.getDate()),
  30. hours = addZero(time.getHours()),
  31. minutes = addZero(time.getMinutes()),
  32. seconds = addZero(time.getSeconds())
  33. // 3. 返回想要的结果
  34. return year + '年' + month + '月' + day + '日' + ' ' + hours + ':' + minutes + ':' + seconds
  35. }
  1. 封装一个公用的时间字符串格式化处理的方式

    String.prototype.formatTime = function formatTime(template) {
    typeof template === ‘undefined’ ? template = “{0}年{1}月{2}日 {3}:{4}:{5}” : null
    // this: 要处理的字符串
    let MatchAry = this.match(/\d+/g)

    template = template.replace(/{(d+)}/g,(x, y)=> {

    1. let val = matchAryy[y] || '00'
    2. val.length < 2 ? val = '0' + val : null
    3. return val

    })
    return template
    }

总结:

今天主要分享一些字符串的常用方法及实现一些常用的需求,时间字符串处理,日期对象的基本操作,封装一个公用的时间字符串处理方式等等,如果想了解更多请关注公众号:
qrcode\_for\_gh\_4d3763fa9780\_258 (1).jpg

发表评论

表情:
评论列表 (有 0 条评论,312人围观)

还没有评论,来说两句吧...

相关阅读