为了账号安全,请及时绑定邮箱和手机立即绑定

有没有人遇到过这个问题哈!寻求scss函数和媒体查询组合方案

有没有人遇到过这个问题哈!寻求scss函数和媒体查询组合方案

桃花长相依 2019-10-16 10:36:05
如题:需求是小于1920px,vw函数直接返回px值,大于1920转换为vw,这样做的目的是在页面中不需要写媒体查询的代码$vw_base:1920;/*设计稿基数*//*尝试将媒体查询融合到SCSS函数*/@mediascreenand(min-width:1920px){@functionvw($px){@return($px/$vw_base)*100vw}}@mediascreenand(max-width:1920px){@functionvw($px){@return$px}}页面中使用.index-comp-ct{width:vw(1920);height:vw(1080);border:1pxsolid;overflow:auto;}但是这样行不通,不知道是否有其他方案
查看完整描述

2 回答

?
蛊毒传说

TA贡献1895条经验 获得超3个赞

自问自答:抛砖引玉我的解决方式:自己搞个loader,处理样式
//vue.config.js
module.exports={
...
chainWebpack:config=>{
constcssRule=config.module.rule('vue')
cssRule
.use(require.resolve('./my-loader.js'))
.loader(require.resolve('./my-loader.js'))
},
...
}
loader:
//my-loader.js
constvwLine=/^\s*(\w+(?:-\w+)?):((\s*vw\(\d+\)){1,4})(\w)*\s*;$/mgi//匹配是否含有vw单位;
constvwValue=/vw\((\d+)\)/
functionreplaceFn(match){
return`@mediascreenand(min-width:1920px){
${match.trim()}
}`+'\n'+`@mediascreenand(max-width:1920px){
${match.replace(vwValue,'$1px')}
}`
}
module.exports=function(content){
content=content.replace(vwLine,replaceFn)
this.callback(null,content)
}
                            
查看完整回答
反对 回复 2019-10-16
?
倚天杖

TA贡献1828条经验 获得超3个赞

Title
这样试试呢
                            
查看完整回答
反对 回复 2019-10-16
  • 2 回答
  • 0 关注
  • 328 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信