el-dialog宽度自适应

最近在自适应上做了很多功夫

其中有一个是,在使用element-plus的el-dialog时,在pc端和在手机端打开,由于屏幕宽度的不同,我希望el-dialog的宽度是不一样的。

而el-dialog设置宽度是通过width属性,直接用%来相对窗口设置宽度。

我先后尝试了媒体查询,监听屏幕宽度和监听视口宽度来自适应。

1️⃣首先,直接给el-dialog设置自定义class结合媒体查询是无效的,直接设置el-dialog的样式属性无效。

复制代码
@media (max-width: 800px) {
  /* 当屏幕宽度小于等于800px时 */
  .el-dialog1{
    width: 90%;
  }
}
@media (min-width: 1000px) and (max-width: 1250px) {
  .el-dialog1{
    width: 60%;
  }
}
@media (min-width: 1250px) {
  .el-dialog1{
    width: 50%;
  }
}

2️⃣监听屏幕宽度window.innerWidth

通过获取window.innerWidth进行判断然后动态设置width属性

可以让我实现手机打开和pc端打开是不同的宽度。

html 复制代码
  <el-dialog v-model="data.dialogVisible" title="" :width="data.width1">

     //...

  </el-dialog>
javascript 复制代码
onMounted(() => {
  if(window.innerWidth <= 1000){
      data.width1 = "80%";      
  }else{
      data.width1 = "50%";
  }
});

但是!这只是获取你操作屏幕的宽度,并不是你窗口的宽度。

当我在pc端用浏览器打开页面,并缩小窗口时,并不会触发宽度的变化。因为window.innerWidth获取的一直都是你设备的宽度。

3️⃣监听视口/窗口宽度document.documentElement.clientWidth;

这时候,改变窗口大小,获取到的宽度就会随之改变了。

但每次窗口修改时我需要刷新才会重新触发修改width的操作,所以这里我再加了个监听视口变化的操作。

javascript 复制代码
onMounted(() => {
  // 添加 resize 事件监听器
  window.addEventListener("resize", watchWidth);
});

watchWidth就是我获取document.documentElement.clientWidth修改width的方法。

这样子再经过调试就可以实现想要的手机电脑自适应效果了。

相关推荐
晓得迷路了1 分钟前
栗子前端技术周刊第 97 期 - Viteland:8 月回顾、Redux Toolkit 2.9、Nuxt 4.1...
前端·javascript·nuxt.js
EndingCoder5 分钟前
Electron 安全性最佳实践:防范常见漏洞
前端·javascript·electron·前端框架·node.js·桌面端
学前端搞口饭吃13 分钟前
React props的使用
前端·javascript·react.js
灵感__idea36 分钟前
JavaScript高级程序设计(第5版):前端的能力边界
前端·javascript·程序员
华洛37 分钟前
SEO还没死,GEO之战已经开始
前端·javascript·产品
不想上班只想要钱1 小时前
vue3 ts:声明的一个数组不能将类型“boolean”分配给类型“never”。
前端·vue.js
F2E_Zhangmo4 小时前
基于cornerstone3D的dicom影像浏览器 第三章 拖拽seriesItem至displayer上显示第一张dicom
前端·javascript·cornerstone·cornerstone3d·cornerstonejs
gnip9 小时前
Jst执行上下文栈和变量对象
前端·javascript
拉不动的猪10 小时前
简单回顾下Weakmap在vue中为何不能去作为循环数据源,以及替代方案
前端·javascript·vue.js
How_doyou_do10 小时前
数据传输优化-异步不阻塞处理增强首屏体验
开发语言·前端·javascript