JavaScript工具类(五):string字符串

String


String 对象用于处理文本(字符串)。

一、属性

属性描述
length字符串的长度。
prototype允许您向对象添加属性和方法。
constructor对创建该对象的函数的引用。

二、常用方法

方法描述
indexOf(searchvalue, fromindex)检索字符串。返回某个指定的字符串值在字符串中首次出现的位置,没有则返回 -1。
charAt(index)返回指定位置的字符,如果参数 index 不在 0 与 length 之间,则返回一个空字符串。
sub()把字符串显示为下标。
substr(start, length)从起始索引号提取字符串中指定数目的字符。返回一个新的字符串,包含从 start(包括start)开始的 length 个字符。如果没有指定length,那么返回的字符串包含从 start 到结尾的字符。(start 可以为负数,-1表示最后一个字符)
substring(start, stop)提取字符串中两个指定的索引号之间的字符。返回一个新的字符串,包含从 start 处到 stop-1 处的所有字符,其长度为 stop 减 start。(参数不可以是负数
slice(start, stop)同上。(参数可以是负数,-1 表示最后一个字符
split(separator, howmany)把字符串分割为字符串数组。返回一个字符串数组
replace(regexp/substr, replacement)在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。
toLowerCase()把字符串转换为小写
toUpperCase()把字符串转换为大写
fontcolor(color)使用指定的颜色来显示字符串。

三、特殊字符

Javascript 中可以使用转义符( 反斜线(\) )插入特殊符号。如下:

代码输出
单引号
"双引号
\斜杆
\n换行
\r回车
\ttab
\b空格
\f换页

四、string 字符串方法封装

u.string = {};

修剪前后空格
/**
 *@description 去除字符串前后空格
 * @param {String} str
 * @return {String} 去除空格之后的字符串
 */
u.trim = function (str) {
    return str.replace(/(^\s*)|(\s*$)/g, "");
};
修剪所有空格
/**
 *@description 去除字符串所有空格
 * @param {String} str
 * @return {String} 去除空格之后的字符串
 */
u.trimAll = function (str) {
    return str.replace(/\s*/g, '');
};
格式化字符串(文本替换)
/**
* @description 格式化字符串(文本替换)
* @param {String} str 源字符串。如:'确定要{0}单据【{1}】吗?'
* @param {*} args 要替换的参数。如:'删除', 'QZYDYJZB201901300002'
* @return {String} 如:'确定要删除单据【QZYDYJZB201901300002】吗?'
*/
u.string.format = function(str, args) {
    for (var i = 1; i < arguments.length; i++) {
        var reg = new RegExp('\\{' + (i - 1) + '\\}', 'gm')
        arguments[0] = arguments[0].replace(reg, arguments[i])
    }
    return arguments[0]
}
判断字符串是否以指定字符串开头
/**
 * @description 判断字符串是否以指定字符串开头
 * @param {String} str 源字符串
 * @param {String} searchString 要查询的字符串
 * @param {Boolean} ignoreCase 是否忽略大小写,默认false
 * @return {Boolean}
 */
u.string.isStartWith = function(str, searchString, ignoreCase) {
    if (str === null || str === undefined) return false
    var preSubStr = str.substring(0, searchString.length) + ''
    if (ignoreCase) {
        preSubStr = preSubStr.toLowerCase()
        searchString = (searchString + '').toLowerCase()
    }
    return preSubStr === searchString
}
判断字符串是否以指定字符串结束
/**
 *@description 判断字符串是否以指定字符串结束
 * @param {String} str 源字符串
 * @param {String} searchString 要查询的字符串
 * @param {Boolean} ignoreCase 是否忽略大小写,默认false
 * @return {Boolean}
 */
u.string.isEndWith = function(str, searchString, ignoreCase) {
    if (str === null || str === undefined) return false
    var lastSubStr = str.substring(str.length - searchString.length, str.length) + ''
    if (ignoreCase) {
        lastSubStr = lastSubStr.toLowerCase()
        searchString = (searchString + '').toLowerCase()
    }
    return lastSubStr === searchString
}
首字母小写
/**
 * @description 首字母小写
 * @param {String} str 源字符串
 * @return {String}
 */
u.string.firstLowerCase = function(str) {
    if (u.isEmpty(str)) return ''
    return str.replace(/^\S/, function(s) { return s.toLowerCase() })
}
首字母大写
/**
 *@description 首字母大写
 * @param {String} str 源字符串
 * @return {String}
 */
u.string.firstUpperCase = function(str) {
    if (u.isEmpty(str)) return ''
    return str.replace(/^\S/, function(s) { return s.toUpperCase() })
}
反转字符串的元素顺序
/**
 * @description 反转字符串的元素顺序
 * @param {String} str 源字符串
 * @return {String}
 */
u.string.reverse = function(str) {
    if (u.isEmpty(str)) return ''

    var newStr = ''
    for (var i = str.length - 1; i >= 0; i--) {
        newStr += str[i]
    }
    return newStr
}
复制文本到剪切板
/**
 * @description 复制文本到剪切板
 * @param text {String} 需要复制的文本内容
 */
u.string.copy = function(text) {
    var input = window.document.createElement('input')
    input.value = text
    input.select()
    window.document.execCommand('copy')
}
字母和数字混合的编号自加1(以数字结尾)
/**
 * @description 字母和数字混合的编号自加1(以数字结尾)
 * @param {String} code 编号。例:'XM0001'
 * @return {String} 编号+1。例:'XM0002'
 */
u.string.getNext = function(code) {
    var part1, part2
    if (/[a-z]/i.test(code)) {
        var x = code.match(/[a-z]/ig)
        part1 = x.join('')
        part2 = code.substring(x.length)
    }
    else {
        part1 = ''
        part2 = code
    }
    var int = parseInt(part2)
    var zero = (part2 + '.').split(int + '.')[0]
    var newPart2 = zero + (int + 1).toString()
    return part1 + newPart2
}

下载

npm i sg-utils -S

GitHub地址(记得给星哦)

https://github.com/shiguang0116/sg-utils


系列文章

JavaScript工具类(一):util.js创建及上传
JavaScript工具类(二):cookie缓存
JavaScript工具类(三):localStorage本地储存
JavaScript工具类(四):数据类型
JavaScript工具类(五):string字符串
JavaScript工具类(六):number数字
JavaScript工具类(七):array数组
JavaScript工具类(八):object对象
JavaScript工具类(九):date日期
JavaScript工具类(十):base64编码、解码
JavaScript工具类(十一):浏览器、移动端类型
JavaScript工具类(十二):validate表单验证
JavaScript工具类(十三):url路径处理
JavaScript工具类(十四):json数据格式
JavaScript工具类:util.js用法实例


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值