一、字符串不可变
字符串不可变:指的是里面的值不可变,虽然看上去可以改变内容,但其实是地址变了,内存中新开辟了一个内存空间。
二、根据字符返回位置
字符串所有的方法,都不会修改字符串本身(字符串是不可变的),操作完成会返回一个新的字符串。
语法:str.indexOf(‘要查找的字符’,[起始的位置])
<script>
//字符串对象,根据字符串返回位置 str.indexOf('要查找的字符',[起始的位置])
var str = '改革春风吹满地,春天来了';
console.log(str.indexOf('春'));
console.log(str.indexOf('春', 3));
</script>
三、根据位置返回字符
//1、charAt(index)根据位置返回字符
var str = 'andy';
console.log(str.charAt(3));
//遍历所有字符
for (var i = 0; i < str.length; i++) {
console.log(str.charAt(i));
}
//2、charCodeAt(index)返回相应索引号的字符ASCII值,目的:判断用户按下了哪个键
console.log(str.charCodeAt(0)); //97
//3、str[index] H5新增的
console.log(str[0]);
四、字符串操作方法
<script>
//字符串操作方法
//1、concat('字符串1','字符串2'...)
var str = 'andy';
console.log(str.concat('red'));
//2、substr('截取的起始位置','截取几个字符')
var str1 = '改革春风吹满地';
console.log(str1.substr(2, 2));
</script>
五、字符串常见题型
1、有一个字符串 ‘abcoefoxyozzopp’ 要求把里面所有的o替换为*。
var str1 = 'abcoefoxyozzopp';
while (str1.indexOf('o') !== -1) {
str1 = str1.replace('o', '*')
}
console.log(str1);
2、字符转换为数组split(‘分隔符’)。
var str2 = 'red,pink,blue';
console.log(str2.split(','));
var str3 = 'red&pink&blue';
console.log(str3.split('&'));
3、判断一个字符串’abcoefoxyozzopp’中出现次数最多的字符,并统计其次数。
//核心算法:利用charAt() 遍历这个字符串
//把每个字符都存储给对象,如果对象没有该属性,就为1,如果存在了就+1
//遍历对象,得到最大值和该字符
var str = 'abcoefoxyozzopp';
var o = {};
for (var i = 0; i < str.length; i++) {
var chars = str.charAt(i);
if (o[chars]) {
o[chars]++;
} else {
o[chars] = 1;
}
}
console.log(o);
//2、遍历对象
var max = 0;
var ch = '';
for (var k in o) {
if (o[k] > max) {
max = o[k];
ch = k;
}
}
console.log(max);
console.log('最多的字符是' + ch);
4、查找字符串”abcoefoxyozzopp”中所有o出现的位置以及次数。
//核心算法:先查找第一个o出现的位置
//然后,只要indexOf返回的结果不是-1,就继续往后查找
//因为indexOf只能查找到第一个,所以后面的查找,一定是当前索引加1,从而继续查找
var str = "oabcoefoxyozzopp";
var index = str.indexOf('o');
var num = 0;
// console.log(index);
while (index !== -1) {
console.log(index);
num++;
index = str.indexOf('o', index + 1);
}
console.log('o出现的次数是:' + num);
//作业:['red','blue','red','green','pink','red'],求red出现的位置和次数
var str1 = ['red', 'blue', 'red', 'green', 'pink', 'red'];
var index1 = str1.indexOf('red');
var num = 0;
while (index1 !== -1) {
console.log(index1);
num++;
index1 = str1.indexOf('red', index1 + 1);
}
console.log('red出现的次数为' + num);
总结:
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/6284.html