字符串查询替换算法挑战

主要就是解决要替换的和替换后的首字母大小写是否一致的问题:
可以利用string.charCodeAt()查看他的字符ascll码
a~z:97-122
A~Z:65~90
他们之间相差32清楚了他们的ascll码就可以利用toUpperCase和toLowerCase进行转化了


function myReplace(str, before, after) {
	var list=str.split(" ");
	for(var i=0;i<list.length;i++){
		if(list[i]==before){
//			console.log(String.charCodeAt('A'));
			console.log(list[i].charCodeAt(0));
//			小于97就是大写
			if(list[i].charCodeAt(0)<97&&after[0].charCodeAt()>=97){
				after=after[0].toUpperCase()+after.substr(1);
			}else if(list[i].charCodeAt(0)>=97&&after[0].charCodeAt()<97){
				after=after[0].toLowerCase()+after.substr(1);
			}
			
			list[i]=after;
		}
	}
	str=list.join(' ');
	console.log(str);
return str;
}
myReplace("A quick brown fox jumped over the lazy dog", "jumped", "leaped");

你可能感兴趣的:(js算法入门)