CoffeeScript-이해력

이전 장에서 우리는 CoffeeScript에서 제공하는 다양한 루프를 배웠습니다. while및 그 변형. 그 외에도 CoffeeScript는 다음과 같은 추가 루프 구조를 제공합니다.comprehensions.

이러한 이해는 for선택적 가드 절과 현재 배열 인덱스의 값을 명시 적으로 추가하면 다른 프로그래밍 언어에서 루프가 발생합니다. comprehensions를 사용하면 배열과 객체를 반복 할 수 있고 배열을 반복하는 comprehension은 표현식이며 함수로 반환하거나 변수에 할당 할 수 있습니다.

S. 아니. 성명 및 설명
1 for..in comprehensions

그만큼 for..in comprehension은 CoffeeScript에서 이해의 기본 형태입니다. 이것을 사용하여 목록이나 배열의 요소를 반복 할 수 있습니다.

2 for..of 이해

배열과 마찬가지로 CoffeeScriptScript는 객체로 알려진 키-값 쌍을 저장하는 컨테이너를 제공합니다. 객체를 반복 할 수 있습니다.for..of CoffeeScript에서 제공하는 이해력.

list comprehensions

그만큼 list CoffeeScript의 이해는 객체 배열을 다른 배열에 매핑하는 데 사용됩니다.

이해 색인

요소의 목록 / 배열에는 이해에 사용할 수있는 색인이 있습니다. 아래와 같이 변수를 사용하여 이해력으로 사용할 수 있습니다.

for student,i in [element1, element2, element3]

다음 예제는 인덱스의 사용법을 보여줍니다. for…inCoffeeScript에 대한 이해. 이 코드를 이름이있는 파일에 저장for_in_index.coffee

for student,i in ['Ram', 'Mohammed', 'John']
   console.log "The name of the student with id "+i+" is: "+student

열기 command prompt 다음과 같이 .coffee 파일을 컴파일합니다.

c:\> coffee -c for_in_index.coffee

컴파일시 다음과 같은 JavaScript를 제공합니다.

// Generated by CoffeeScript 1.10.0
(function() {
  var i, j, len, ref, student;

  ref = ['Ram', 'Mohammed', 'John'];
  for (i = j = 0, len = ref.length; j < len; i = ++j) {
    student = ref[i];
    console.log("The name of the student with id " + i + " is: " + student);
  }
}).call(this);

이제 command prompt 다시 다음과 같이 CoffeeScript 파일을 실행합니다.

c:\> coffee for_in_index.coffee

실행시 CoffeeScript 파일은 다음 출력을 생성합니다.

The name of the student with id 0 is: Ram
The name of the student with id 1 is: Mohammed
The name of the student with id 2 is: John

이해의 후위 형식

접미사처럼 ifunless, CoffeeScript는 코드를 작성하는 동안 편리한 Comprehensions의 접미사 형식을 제공합니다. 이것을 사용하여 우리는for..in 아래 그림과 같이 한 줄로 이해하십시오.

#Postfix for..in comprehension
console.log student for student in ['Ram', 'Mohammed', 'John']

#postfix for..of comprehension
console.log key+"::"+value for key,value of { name: "Mohammed", age: 24, phone: 9848022338}
예시보기

변수에 할당

배열을 반복하는 데 사용하는 이해력은 변수에 할당 될 수 있으며 함수에 의해 반환 될 수도 있습니다.

아래 주어진 예를 고려하십시오. 여기서 우리는 다음을 사용하여 배열의 요소를 검색 한 것을 볼 수 있습니다.for..in 이해하고 이것을라는 변수에 할당했습니다. names. 그리고 우리는 또한 다음을 사용하여 명시 적으로 이해를 반환하는 함수가 있습니다.return예어. 이 코드를 이름이있는 파일에 저장example.coffee

my_function =->
   student = ['Ram', 'Mohammed', 'John']
   
   #Assigning comprehension to a variable
   names = (x for x in student )
   console.log "The contents of the variable names are ::"+names
   
   #Returning the comprehension
   return x for x in student
console.log "The value returned by the function is "+my_function()

열기 command prompt 다음과 같이 .coffee 파일을 컴파일합니다.

c:\> coffee -c example.coffee

컴파일시 다음과 같은 JavaScript를 제공합니다.

// Generated by CoffeeScript 1.10.0
(function() {
  var my_function;

  my_function = function() {
    var i, len, names, student, x;
    student = ['Ram', 'Mohammed', 'John'];
    names = (function() {
      var i, len, results;
      results = [];
      for (i = 0, len = student.length; i < len; i++) {
        x = student[i];
        results.push(x);
      }
      return results;
    })();
    console.log("The contents of the variable names are ::" + names);
    for (i = 0, len = student.length; i < len; i++) {
      x = student[i];
      return x;
    }
  };

  console.log("The value returned by the function is " + my_function());

}).call(this);

이제 command prompt 다시 다음과 같이 CoffeeScript 파일을 실행합니다.

c:\> coffee example.coffee

실행시 CoffeeScript 파일은 다음 출력을 생성합니다.

The contents of the variable names are ::Ram,Mohammed,John
The value returned by the function is Ram

키워드 별

CoffeeScript는 요소 목록을 정의하는 범위를 제공합니다. 예를 들어 [1..10] 범위는 [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]과 같습니다. 여기서 모든 요소는 1 씩 증가합니다.이 증가분을 변경할 수도 있습니다. 사용by 이해의 키워드.

다음 예제는 by 의 키워드 for..inCoffeeScript에서 제공하는 이해력. 이 코드를 이름이있는 파일에 저장by_keyword_example.coffee

array = (num for num in [1..10] by 2)
console.log array

열기 command prompt 다음과 같이 .coffee 파일을 컴파일합니다.

c:\> coffee -c by_keyword_example.coffee

컴파일시 다음과 같은 JavaScript를 제공합니다.

// Generated by CoffeeScript 1.10.0
(function() {
  var array, num;

  array = (function() {
    var i, results;
    results = [];
    for (num = i = 1; i <= 10; num = i += 2) {
      results.push(num);
    }
    return results;
  })();

  console.log(array);

}).call(this);

이제 command prompt 다시 다음과 같이 CoffeeScript 파일을 실행합니다.

c:\> coffee by_keyword_example.coffee

실행시 CoffeeScript 파일은 다음 출력을 생성합니다.

[ 1, 3, 5, 7, 9 ]