> 웹 프론트엔드 > JS 튜토리얼 > JavaScript_javascript 기술의 작동 문자열 요약

JavaScript_javascript 기술의 작동 문자열 요약

WBOY
풀어 주다: 2016-05-16 16:01:09
원래의
1033명이 탐색했습니다.

저는 최근 프론트엔드 인턴 채용을 위한 여러 필기 시험에 참여했는데, Qunar.com 필기 시험 문제, Taobao 필기 시험 문제 등과 같은 많은 필기 시험 문제가 문자열 처리를 테스트한다는 것을 알게 되었습니다. 필기 시험을 자주 보거나 가본 적이 있다면 나처럼 문자열 처리가 프런트 엔드 채용 프로세스에서 가장 일반적인 질문 유형 중 하나라는 것을 알게 될 것입니다.

이 질문들은 한 가지 특징이 있습니다. 시험관 입장에서 생각해 보세요. 알고 있는지가 아니라, XX 매뉴얼이나 XX 가이드, 바이두, 구글을 빌리지 않고도 좀 더 간결하게 사용할 수 있는지를 테스트합니다. 방법.

안타깝게도 나도 그중 한 명인 많은 개발자들이 자주 사용되는 문자열 처리 기능의 사용법을 확실히 기억하지 못하고 항상 XX 매뉴얼이나 XX 가이드나 Baidu Google을 참조해야 합니다.

이 결과는 매우 중요한 기본 지식이 충분히 강력하지 않다는 것입니다. 이러한 질문에 직면하면 N 수준 중첩 for 루프를 사용하여 하나씩 탐색해야 합니다.

이러한 유형의 질문을 할 때 for 루프를 너무 많이 사용하고 있다면 주의하세요. 이러한 것들을 과소평가하지 마십시오. 일자리를 찾고 일상적인 발전에 큰 역할을 할 수 있습니다.

자, 더 이상 이야기하지 말고 하나씩 요약해 보겠습니다. 혹시 누락된 부분이 있을 수 있으니, 발견하신 경우에는 자유롭게 추가하시거나 비공개 메시지를 보내주세요.

1. 문자열 변환

문자열 변환은 가장 기본적인 요구 사항이며 작업은 다음 세 가지 방법 중 하나를 사용하여 모든 유형의 데이터를 문자열로 변환할 수 있습니다.

var num= 19; // 19
var myStr = num.toString(); // "19"
로그인 후 복사
다음과 같이 할 수도 있습니다.

var num= 19; // 19
var myStr = String(num); // "19"
로그인 후 복사
또는 더 간단하게:

var num= 19; // 19
var myStr = "" +num; // "19"
로그인 후 복사

2. 문자열 분할

문자열 분할은 문자열을 여러 문자열로 분할하는 것입니다. JavaScript는 다음과 같은 매우 편리한 기능을 제공합니다.

var myStr = "I,Love,You,Do,you,love,me";
var substrArray = myStr .split(","); // ["I", "Love", "You", "Do", "you", "love", "me"];
var arrayLimited = myStr .split(",", 3); // ["I", "Love", "You"];
로그인 후 복사
split()의 두 번째 매개변수는 반환되는 문자열 배열의 최대 길이를 나타냅니다.

3. 문자열 길이를 가져옵니다

문자열 길이는 개발에서 자주 사용됩니다. 다음과 같이 매우 간단합니다.

var myStr = "I,Love,You,Do,you,love,me";
var myStrLength = myStr.length; //25
로그인 후 복사

4. 하위 문자열 쿼리

많은 사람들이 이러한 JavaScript의 내장 메소드를 잊어버리거나 특정 사용법을 잊어버리므로 질문을 할 때 for 루프를 중첩해야 합니다.

첫 번째 함수: indexOf()는 문자열의 처음부터 검색하여 해당 좌표가 없으면 -1을 반환합니다. 다음과 같습니다:

var myStr = "I,Love,you,Do,you,love,me";
var index = myStr.indexOf("you"); // 7 ,基于0开始,找不到返回-1
로그인 후 복사
두 번째 함수: lastIndexOf()는 문자열의 끝부터 검색하여 해당 좌표가 없으면 -1을 반환합니다. 다음과 같습니다:

var myStr = "I,Love,you,Do,you,love,me";
var index = myStr.lastIndexOf("you"); // 14
로그인 후 복사
위의 두 함수는 검색 시작 위치를 나타내는 두 번째 선택적 매개변수도 받습니다.

5. 문자열 교체

문자열 찾는 것만으로는 끝나서는 안 됩니다. 일반적인 질문에서는 문자열을 찾아 자신만의 문자열로 바꾸라는 요청을 받는 경우가 많습니다. 예를 들면 다음과 같습니다.

var myStr = "I,love,you,Do,you,love,me";
var replacedStr = myStr.replace("love","hate");//"I,hate,you,Do,you,love,me"
로그인 후 복사
기본적으로 처음 발견된 항목만 교체됩니다. 전역적으로 교체하려면 다음과 같은 일반 전역 플래그를 넣어야 합니다.

var myStr = "I,love,you,Do,you,love,me";
var replacedStr = myStr.replace(/love/g,"hate");
//"I,hate,you,Do,you,hate,me"
로그인 후 복사
자세한 설명은

http://www.w3school.com.cn/jsref/jsref_replace.asp를 참고하세요.

6. 특정 위치의 문자 또는 해당 문자 인코딩 값을 찾습니다.

특정 위치에서 문자를 찾으려면 다음 기능을 사용할 수 있습니다.

var myStr = "I,love,you,Do,you,love,me";
var theChar = myStr.charAt(8);// "o",同样从0开始
로그인 후 복사
마찬가지로 형제 함수 중 하나는 다음과 같이 해당 위치의 문자 인코딩 값을 찾는 것입니다.


var myStr = "I,love,you,Do,you,love,me";
var theChar = myStr.charCodeAt(8); //111
로그인 후 복사

7. 문자열 연결

문자열 연결 작업은 다음과 같은 추가 연산자를 사용하는 것만큼 간단할 수 있습니다.

var str1 = "I,love,you!";
var str2 = "Do,you,love,me?";
var str = str1 + str2 + "Yes!";//"I,love,you!Do,you,love,me?Yes!"
로그인 후 복사
마찬가지로 JavaScript에는 다음과 같은 관련 기능도 함께 제공됩니다.


var str1 = "I,love,you!";
var str2 = "Do,you,love,me?";
var str = str1.concat(str2);//"I,love,you!Do,you,love,me?"
로그인 후 복사
concat() 함수는 여러 매개변수를 가질 수 있고, 여러 문자열을 전달하고, 여러 문자열을 연결할 수 있습니다.

8. 문자열 자르기 및 추출

문자열에서 추출하고 잘라내는 방법에는 다음과 같은 세 가지가 있습니다.

첫 번째 방법은 Slice()를 사용하는 것입니다.


var myStr = "I,love,you,Do,you,love,me";
var subStr = myStr.slice(1,5);//",lov"
로그인 후 복사
두 번째로 하위 문자열()을 사용합니다.


var myStr = "I,love,you,Do,you,love,me";
var subStr = myStr.substring(1,5); //",lov"
로그인 후 복사
세 번째 방법은 substr()을 사용하는 것입니다.


var myStr = "I,love,you,Do,you,love,me";
var subStr = myStr.substr(1,5); //",love"
로그인 후 복사
첫 번째, 두 번째 방법과 다르게 substr()의 두 번째 매개변수는 위 결과에서 볼 수 있듯이 가로채는 문자열의 최대 길이를 나타냅니다.

9. 문자열 대소문자 변환

대문자 또는 소문자 문자열로 변환하기 위해 일반적으로 사용되는 함수는 다음과 같습니다.


var myStr = "I,love,you,Do,you,love,me";
var lowCaseStr = myStr.toLowerCase();//"i,love,you,do,you,love,me";
var upCaseStr = myStr.toUpperCase();//"I,LOVE,YOU,DO,YOU,LOVE,ME"
로그인 후 복사
10. 문자열 매칭

문자열 일치를 위해서는 정규 표현식에 대한 어느 정도의 이해가 필요할 수 있습니다. 먼저 match() 함수를 살펴보겠습니다.


var myStr = "I,love,you,Do,you,love,me";
var pattern = /love/;
var result = myStr.match(pattern);//["love"]
console.log(result .index);//2
console.log(result.input );//I,love,you,Do,you,love,me
로그인 후 복사

如你所见,match()函数在字符串上调用,并且接受一个正则的参数。来看看第二个例子,使用exec()函数:

var myStr = "I,love,you,Do,you,love,me";
var pattern = /love/;
var result = pattern .exec(myStr);//["love"]
console.log(result .index);//2
console.log(result.input );//I,love,you,Do,you,love,me
로그인 후 복사

简单吧,仅仅是把正则和字符串换了个位置,即exec()函数是在正则上调用,传递字符串的参数。对于上面两个方法,匹配的结果都是返回第一个匹配成功的字符串,如果匹配失败则返回null.

再来看一个类似的方法search(),如:

var myStr = "I,love,you,Do,you,love,me";
var pattern = /love/;
var result = myStr.search(pattern);//2
로그인 후 복사

仅返回查到的匹配的下标,如果匹配失败则返回-1.

11、字符串比较

比较两个字符串,比较是规则是按照字母表顺序比较的,如:

var myStr = "chicken";
var myStrTwo = "egg";
var first = myStr.localeCompare(myStrTwo); // -1
first = myStr.localeCompare("chicken"); // 0
first = myStr.localeCompare("apple"); // 1
로그인 후 복사

12、举例

最后我们来看一道前端笔试题,去哪儿网的,相信很多孩子都做到过这个题了。题目:写一个getSuffix函数,用于获得输入参数的后缀名,例如输入abcd.txt,返回txt。附上我的答案:

function getSuffix(file){
   return file.slice(file.lastIndexOf(".") + 1,file.length); 
}
로그인 후 복사

结束语

相信JavaScript中字符串操作的函数应该不止这几个,但是上面列的这些应该都是非常常用的。如果有哪些需要补充的,欢迎补充!希望看到这些以后,再面对字符串的笔试面试题你能非常从容的面对。

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿