js字符串常用方法

1、基本包装类型

var 1 = 'abc';
var len = s1.length;
console.log(len);  // 3

这段代码在执行时,有一个问题就是基本类型是没有属性方法的,那么s1.length是怎么调用的呢?这就是用到基本包装类型。就是把基本类型包装成复杂类型。
基本包装类型:String/Number/Boolean

var s = new String('123');
console.log(s);  // String {"123"}  PrimitiveValue原始值


s1.length执行过程

var _s1 = new String('abc');  // 创建临时对象
var len = _s1.length;   // 调用属性
_s1 = null;  // 销毁对象

2、字符串
特点:不可变

var s = 'abc';
s = 'sxsd';
// 当重新给str赋值的时候,常量'abc'不会被修改,依然在内存中
// 重新给字符串赋值,会重新在内存中开辟空间,这个特点就是字符串的不可变
// 由于字符串的不可变,在大量拼接字符串的时候会有效率问题

(1)、创建字符串对象

var str = new String('Hello World');

// 获取字符串中字符的个数
console.log(str.length);

(2)、字符串对象的常用方法
字符串所有的方法,都不会修改字符串本身(字符串是不可变的),操作完成会返回一个新的字符串。

// 1 字符方法
charAt()    	//获取指定位置处字符
charCodeAt()  	//获取指定位置处字符的ASCII码

// 2 字符串操作方法
concat()   		//拼接字符串,等效于+,+更常用
slice()    		//从start位置开始,截取到end位置,end取不到
substring() 	//从start位置开始,截取到end位置,end取不到
substr()   		//从start位置开始,截取length个字符

// 3 位置方法
indexOf()   	//返回指定内容在元字符串中的位置,从前往后找第一个
lastIndexOf() 	//从后往前找,只找第一个匹配的

// 4 去除空白   
trim()  		// 只能去除字符串前后的空白,字符串之间的空格不能去掉

// 5 大小写转换方法
to(Locale)UpperCase() 	//转换大写
to(Locale)LowerCase() 	//转换小写

// 6 其它
search()  // 不存在返回-1,search支持正则。
replace() // 替换
split() // 返回数组
fromCharCode()
// String.fromCharCode(101, 102, 103);	 //把ASCII码转换成字符串

案例:

// 截取字符串"我爱中华人民共和国",中的"中华"
var s = "我爱中华人民共和国";
s = s.substr(2,2);
console.log(s);


// "abcoefoxyozzopp"查找字符串中所有o出现的位置
var s = 'abcoefoxyozzopp';
var array = [];
do {
  var index = s.indexOf('o', index + 1);
  if (index != -1) {
    array.push(index);
  }
} while (index > -1);
console.log(array);


//  把字符串中所有的o替换成!
var s = 'abcoefoxyozzopp';
do {
  s = s.replace('o', '');
} while (s.indexOf('o') > -1);
console.log(s);

console.log(s.replace(/o/ig, ''));


// 判断一个字符串中出现次数最多的字符,统计这个次数
var s = 'abcoefoxyozzopp';
var o = {};
for (var i = 0; i < s.length; i++) {
  var item = s.charAt(i);
  if (o[item]) {
    o[item] ++;
  }else{
    o[item] = 1;
  }
}
var max = 0;
var char ;
for(var key in o) {
  if (max < o[key]) {
    max = o[key];
    char = key;
  }
}
console.log(max);
console.log(char);

你可能感兴趣的:(js学习)