애플리케이션의 scss 파일에서 @import를 호출 할 수 있도록 라이브러리에서 가져온 scss 폴더를 선언 / 포함하려면 어떻게해야합니까?
목표:
@import
다음과 같이 내 응용 프로그램에 scss 파일을 포함 하는 문을 사용할 수 있도록 내 라이브러리의 경로를 포함하려고합니다 .
@import "some-scss-in-my-lib"
문제 :
불행히도 내 응용 프로그램을 제공하려고 할 때마다 다음 컴파일러 오류가 발생합니다.
SassError: Can't find stylesheet to import.
내가 이미 시도한 것 :
Stackoverflow에서 검색을 검색 하면 지금 당면한 것과 동일한 문제를 설명하는 이 스레드 를 가져 왔습니다 . 그리고 Zainu가 제안한
styleIncludePaths
것처럼 속성에 경로를 포함하려고 시도했지만 응용 프로그램을 제공하려고 할 때 위의 The Problem -Section 에서 설명한대로 정확한 문제를 실행했습니다 .첫 번째 게시물에서 GreatHawkeye
stylePreprocessorOptions
와 같은 속성 을 설정하려고했는데 사용 후 scss 파일 에 가능 했지만 이것이 작동하는 방법과 이유를 이해할 수 없지만 작동 하지 않습니까?@import
ng build
stylePreprocessorOptions
styleIncludePaths
나는 또한 Alan Aguis 의 답변을 찾은 Thread Unable to get styles bundled using styleIncludePaths 옵션으로 안내 하는 Google 검색을 시도 했지만 불행히도 styleIncludePaths가 실제로 무엇인지에 대한 실제 설명은 없었습니다. 있는 유일한 것은 앨런 Aguis는 말했다이었다 :
이는 styleIncludePaths가 다른 것에 대해 들여 쓰기되기 때문입니다.
그러나 말했듯이 그는 정확히 styleIncludePaths가 무엇인지에 대해 말하지 않았기 때문에 나를 더욱 혼란스럽게 만들었습니다.
또한 스레드에서 "styleIncludePaths"를 사용하는 방법 에 대한 스타일 포함 경로 추가 에 대한 문서와 관련 하여 ng-packagr github 페이지 를 조회하려고 했지만 결과는 여전히 동일하고 내 문제에 대한 명확한 답을 찾을 수 없었습니다.
이 문제에 대한 질문 :
ng-package.json의 styleIncludePaths는 언제 사용됩니까? 게시 된 패키지에만 사용됩니까?
angular.json의 stylePreprocessorOptions는 언제 사용됩니까? 가 사용된다 DIST 에만 빌드를 ng를 실행 한 후 버전?
일반적으로 ng-package.json의 styleIncludePaths와 angular.json의 stylePreprocessorOptions의 차이점은 무엇입니까?
애플리케이션의 scss 파일에서 @import를 호출 할 수 있도록 라이브러리에서 가져온 scss 폴더를 선언 / 포함하려면 어떻게해야합니까?
내 제안이 잘못되었다고 확신하지만 무슨 일이 일어나고 있는지 그리고 내 문제를 해결하는 방법을 알고 싶습니다.
이것에 대한 도움은 항상 높이 평가됩니다! 🙏🏻
답변
github 에서 대답했듯이 alan-agius4를 인용합니다 .
포함 경로는 라이브러리를 빌드하는 동안 CSS 프로세서에서 scss / less / stylus 파일을 처리 할 때 가져 오기를 확인하는 데 사용됩니다. 처리되지 않은 scss 파일의 경우 이러한 경로는 라이브러리 빌드 파이프 라인이 아니라 애플리케이션의 라이브러리 수준 대신 애플리케이션 수준에 포함되어야합니다. 정적 파일로 복사됩니다. 애플리케이션 수준에서 이러한 경로를 포함하지 않으려는 경우 웹팩의 물결표 가져 오기 구문을 활용할 수 있습니다. 예 :
@import "~/my-lib/scss/mixins”.
참고 : 웹팩 특정 기능은 Angular 도구 팀에서 공식적으로 지원하지 않으며 경고없이 중단 될 수 있습니다.