webpack - Nativescript 6 angular如何将SCSS文件动态加载到页面中
问题描述
我有一个项目,我正在努力像以前使用 Webpack、Nativescript 5.x 和 SASS 一样进行工作。
在 {N} 6 出现之前,SASS 插件将 .scss 文件编译成 .css 文件以及它们的 scss 对应文件。
我正在使用此功能根据在 ngAfterViewInit() 中调用的以下函数将特定于设备大小的 css 动态加载到我的页面中。
现在因为 {N}6 使用 sass-loader 而不是 nativscript-dev-sass 没有创建 css 文件,所以我所有的 css 规则都进入了 bundle.js,我不知道如何获取我需要应用的 CSS这页纸。
基本上 this.page.addCssFile() 已经没用了。
有谁知道如何访问 bundle.js 中的原始 css,或者如何配置我的 webpack 构建以发出 css 文件?
基本上我只想为 /app/styles/ 中的 .scss 文件生成 .css 文件,将它们包含在我的构建中,然后像在下面的函数中那样调用它们。
欢迎提出其他实现我目标的方法的建议。我曾尝试使用 mini-css-extract-plugin 创建 css 文件,但我对 Webpack 不是很熟悉。
constructor(protected page: Page, protected routerExtensions : RouterExtensions ){
...
private setupScreenSize(){
let screen = platform.screen.mainScreen;
let orient = orientation.getOrientation();
console.log(orient);
console.log(screen.heightDIPs);
console.log(screen.widthDIPs);
console.log("Current directory: " + __dirname)
if( screen.widthDIPs <= 320 || screen.heightDIPs <= 320){
console.log("small screen");
this.screenSize = "screen-small"
this.page.addCssFile("~/styles/device-small.css")
} else if ( screen.widthDIPs <= 480 || screen.heightDIPs <= 480) {
console.log("medium screen");
this.screenSize = "screen-medium"
this.page.addCssFile("~/styles/device-medium.css")
} else if ( screen.widthDIPs <= 600 || screen.heightDIPs <= 600) {
console.log("large screen");
this.screenSize = "screen-large"
this.page.addCssFile("~/styles/device-large.css")
} else {
console.log("extra large screen");
this.screenSize = "screen-xlarge"
this.page.addCssFile("~/styles/device-extra-large.css")
}
...
}
解决方案
推荐阅读
- r - 如何使用ggplot更改散点图中数据的颜色
- android - BillingClient.BillingClientStateListener.onBillingSetupFinished 被多次调用
- python - 如何从 Pandas to_sql db 添加行
- javascript - 在使用 rails/webpacker 的 vue 应用程序中使用 vuetify 自定义 sass 变量
- sql - SQL 文本匹配
- ios - 进入/退出地理围栏时,我可以在 iOS 后台设置 Firebase 用户属性吗?
- javascript - 类型错误:react__WEBPACK_IMPORTED_MODULE_0___default(...) 不是函数
- android - 如何在 MaterialDatePicker 中禁用过去的日期?
- node.js - 将nodejs项目从一台PC移动到另一台
- sql - 用于排除一个或多个字符的 MSSQL 通配符