Sass 확장

SASS의 기능을 확장하여 사용자에게 다양한 유형의 기능과 사용자 정의를 제공 할 수 있습니다. 이러한 기능을 사용하려면 Ruby에 대한 지식이 있어야합니다.

사용자 정의 SASS 함수 정의

Ruby API를 사용하는 동안 고유 한 SASS 함수를 정의 할 수 있습니다. 다음 코드와 같이 Ruby 메서드에 추가하여 사용자 지정 함수를 추가 할 수 있습니다.

module Sass::Script::Functions
   def reverse(string)
      assert_type string, :String
      Sass::Script::Value::String.new(string.value.reverse)
   end
   declare :reverse, [:string]
end

볼 수있는 코드에서 함수 선언은 함수의 인수 이름을 지정합니다. 실패하면 함수가 작동하더라도 인수를 받아들이지 않으며 임의의 키워드 인수도받습니다. value 접근 자를 사용하여 Ruby 값을 가져 오고 rgb, red, green 또는 blue 를 사용하여 색상 개체에 액세스 할 수 있습니다 .

캐시 저장소

SASS는 구문 분석 된 문서의 캐시를 저장하므로 다시 구문 분석하지 않고 재사용 할 수 있습니다. SASS 사용:cache_location파일 시스템에 캐시 파일을 작성합니다. SASS 파일의 컴파일 속도를 높이고 캐시 된 파일을 삭제하면 다음에 컴파일 할 때 다시 생성됩니다. 다음을 설정하여 고유 한 캐시 저장소를 정의 할 수 있습니다.:cache_store선택권. 이것은 파일 시스템에 캐시 파일을 쓰거나 루비 프로세스 또는 머신에 캐시 파일을 공유합니다. SASS는 Sass :: CacheStores :: Base 의 하위 클래스 인스턴스를 사용하여 캐시 결과를 저장하고 검색합니다.

맞춤 수입 업체

SASS는 @import 를 사용 하여 SCSS 및 SASS 파일을 가져오고 경로를 @import 규칙에 전달 하여 지정된 경로에 대한 적절한 경로 코드를 찾습니다. SASS 임포터는 파일 시스템을 사용하여 코드를로드하고 데이터베이스 또는 다른 파일 이름 지정 체계를 사용하여로드에 추가합니다.

단일 임포터는 단일 파일로드를 수행 할 수 있으며 파일 시스템의 경로와 함께 : load_paths 배열에 배치 할 수 있습니다 . @import를 사용하는 동안 SASS는 임포터의 경로를 가져 오는로드 된 경로를 찾습니다. 경로를 찾으면 가져온 파일이 사용됩니다. 사용자는 다음에서 수입업자를 상속 할 수 있습니다.Sass::Importers::Base.