flex自适应页面

javascript 复制代码
<template>
  <div id="fb-content" :style="{ padding: '0 ' + boxPadding + 'px' }">
    <div
      v-for="(item, index) in props['boxList']"
      :key="index"
      :style="{ width: 100 / boxNum + '%' }"
    >
      <div style="display: flex; justify-content: center">
        <slot name="box" :item="item"></slot>
      </div>
    </div>
  </div>
</template>
<script setup lang="ts">
  import { defineProps, onMounted, ref } from 'vue';
  const props = defineProps({
    boxWidth: {
      type: Number,
      default: 1,
    },
    gap: {
      type: Number,
      default: 1,
    },
    boxList: {
      type: Object,
    },
  });
  const boxNum = ref(0);
  const boxPadding = ref(0);
  onMounted(() => {
    init();
    window.addEventListener('resize', () => {
    //监听页面变化
      init();
    });
  });
  function init() {
    let dom = document.getElementById('fb-content');
    let contentWidth = dom?.clientWidth || dom?.offsetWidth || 1;
    boxNum.value = contentWidth
      ? parseInt((contentWidth - props['gap']) / (props.boxWidth + props['gap']))
      : 1;
    boxPadding.value = parseInt(
      (contentWidth - (props['boxWidth'] + props['gap']) * boxNum.value) / 2,
    );
  }
</script>
<style lang="less">
  #fb-content {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
  }
</style>

间距固定,左右padding自适应

相关推荐
superior tigre1 分钟前
C++学习:六个月从基础到就业——模板编程:模板特化
开发语言·c++·学习
yyywxk17 分钟前
Matlab 报错:尝试将 SCRIPT vl_sift 作为函数执行:
开发语言·matlab
五号厂房19 分钟前
仿照AntDesign,实现一个自定义Tab
前端
码上飞扬19 分钟前
Java大师成长计划之第5天:Java中的集合框架
java·开发语言
Bob999826 分钟前
三大浏览器(Firefox、Opera、Chrome)多个Profile管理!
开发语言·javascript·eclipse·sqlite·ecmascript·hbase
Frankabcdefgh34 分钟前
前端面试 js
开发语言·javascript·原型模式
EnigmaCoder42 分钟前
java面向对象编程【高级篇】之多态
java·开发语言
浏览器爱好者44 分钟前
如何删除Google Chrome中的所有历史记录【一键清除】
前端·chrome
埃兰德欧神1 小时前
三分钟让你的H5变身‘伪原生’,揭秘H5秒变应用的魔法配置
javascript·html·产品
米开朗基杨1 小时前
Cursor 最强竞争对手来了,专治复杂大项目,免费一个月
前端·后端