js中的数组,字符串的处理

最近再刷leetCode上面的一些关于数组和字符串基础题,发现遇到了很多以前没怎么用到的或者用过了也就忘记了的函数,在这里我做个总结。

一、数组中删除元素

        splice(index, howmany,  item1,.....,itemX);

        index:要删除的数的位置

       howmany:从这个位置要删除的数的个数

       item1,.....,itemX:从这个位置添加新的元素

      用法:

var removeDuplicates = function(nums) {
      let len = nums.length;
    for(let i=0;i<len;i++)
        {
            for(let j=i+1;j<len;j++)
                {
                    if(nums[i]===nums[j])
                        {
                            nums.splice(j,1)
                            len--;
                            j--;
                        }
                }
        }
    
};

二、将字符串与数组之间的转换

      字符串转数组:split(separator,howmany)

    separator:根据什么分割,可以是正则表达式,也可以是符号

    howmany :数组的长度,当确定了此长度,便分割出来的数组的长度不会超过此长度

    数组转字符串:join(separator)

    separator:指定分隔符,不写则默认逗号

   用法:

var reverseString = function(s) {
    let len = s.length;
    let a=[];
    a=s.split('');
    let j=0;
    let b=[];
    for(let i=len-1;i>=0;i--)
    {
       b[j]=a[i];
       j++;
    }
    return (b.join(""));
};
三、字符串中的元素替换
replace(regexp/substr,replacement)

regexp/substr:需要替换的数满足什么样的正则表达式或者替换的数。

replacement:换成什么数,或者用什么来进行替换函数。

用法:

var firstUniqChar = function(s) {
    let len = s.length;
	for(let i=0;i<len;i++)
	{
        let str=s[i];
        var result=s.replace(s[i],'0');
        let key = result.indexOf(str);
        if(key===-1)
        {
        	return i;
        }
	}
    return -1;
	
};

str=str.replace(/(^\s*)|(\s*$)/g, "")
四、指定字符串某元素首次出现在字符串中的位置

indexOf(searchvalue,fromindex)

searchvalue:需要检索哪个字符串或者元素

fromindex:可选,开始检索的位置,默认从字符串的首部开始检索

用法

var strStr = function(haystack, needle) {
    return (haystack.indexOf(needle));
};
五、分割数组/分割字符串

分割数组:    slice(start,end)

分割字符串:substring(start,end)

start:必需,起始位置,如果是负数,默认从头开始

end:可选,结束的位置,若省略参数,则到结束

用法:
var test = function() {
	var str="Hello world!"
	var array=[1,2,5,7,8];
	let s= str.substring(2,6);
	let a= array.slice(2,3);
	console.log(a);
	console.log(s);
}





     

猜你喜欢

转载自blog.csdn.net/weixin_40518538/article/details/80812870
今日推荐