欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 综合教程 >内容正文

综合教程

【FCC】freeCodeCamp:Where art thou 替换字符串

发布时间:2023/11/21 综合教程 56 生活家
生活随笔 收集整理的这篇文章主要介绍了 【FCC】freeCodeCamp:Where art thou 替换字符串 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

使用给定的参数对句子执行一次查找和替换,然后返回新句子。

第一个参数是将要对其执行查找和替换的句子。

第二个参数是将被替换掉的单词(替换前的单词)。

第三个参数用于替换第二个参数(替换后的单词)。

注意:替换时保持原单词的大小写。例如,如果你想用单词 "dog" 替换单词 "Book" ,你应该替换成 "Dog"。

String.prototype.replace()的语法:

str.replace(regexp|substr, newSubStr|function)

余下的问题在于如何替换时保持原单词的大小写。这个指的应当是单词的首字母

// 解法1
if(before[0] === before[0].toUpperCase()){
    // ...
}

// 解法2
var reg = /^[A-Z]/;
if(re.test(before.charAt(0))){
    // ...
}

这里顺便说一下访问单个字符时, str[index]charAt(index) 的区别:
对于 超出范围的索引值 , str[index] 将返回 undefined ,而 charAt(index) 将返回一个空字符串。
对于 IE8以下版本 , str[index] 不被兼容,将返回 undefined

解法

// 解法1
function myReplace(str,before,after){
  if(before[0] === before[0].toUpperCase()){
    after = after[0].toUpperCase() + after.slice(1);
  }
  str = str.replace(before,after);
  return str;
}

// 解法2
function myReplace(str,before,after){
  var reg = /^[A-Z]/;
  if(reg.text(before.charAt(0))){
    after = after.charAt(0).toUpperCase() + after.slice(1);
  }
  str = str.replace(before,after);
  return str;
}


//解法3
function myReplace(str, before, after) {
	if(before[0]>='A' && before[0]<='Z'){
		after = after[0].toUpperCase()+after.substring(1);
				}
	str=str.replace(before,after);
	return str;
}

作者:不要变成发抖的小喵喵喵喵喵喵
链接:https://www.jianshu.com/p/4d72dfe478b5

总结

以上是生活随笔为你收集整理的【FCC】freeCodeCamp:Where art thou 替换字符串的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。