【Element plus】走马灯高度自适应

elemen plus走马灯高度有固定值,做pc端轮播图无法根据窗口的宽度,实现高度自适应

解决办法:监听页面缩放

在走马灯外先给一个容器方便处理样式,给走马灯一个响应高度,用ref获取图片节点

<!-- 轮播图 -->
<div class="swiper">
    <el-carousel class="el-carousel" :height="newHeight" :interval="3000" arrow="always">
        <el-carousel-item v-for="item in bannerPic" :key="item">
            <img ref="bannerImg" :src="item.url" style="width:100%;height:100%" alt="">
        </el-carousel-item>
    </el-carousel>
</div>

每次缩放都会触发监听事件,拿到图片高度的值,然后把图片高度的值给到走马灯,但是刚加载,不会触发监听事件,所以需要先给newHeight一个初始值,我这里是估了图片撑满时高度的值。

js:
// 轮播图图片数据
const bannerPic = reactive([
    { url: require("../assets/images/1654155115s6JpXe2Kew.png") },
    { url: require("../assets/images/1645781194NbHxdhxzYr.png") },
    { url: require("../assets/images/1636446752RtKZ5hRhKw.png") }
]);


// 获取轮播图片的节点
  const bannerImg = ref()

// 轮播图自适应高度 
  const newHeight = ref('315px')


//监听屏幕缩放事件,
onMounted(() => {
      window.onresize = () => {
        newHeight.value = bannerImg.value[0].clientHeight + 'px'
      }

css:
.swiper {
  margin: 0 0 40px 0;
  min-width: 1210px;
  overflow: hidden;


  .el-carousel {
    width: 100%;
    overflow: hidden;

    :deep(.el-carousel__container) {
      height: v-bind(newHeight);
    }

    :deep(.el-carousel__item) {
      height: auto !important;
    }
}

这个方法感觉并不是很完美,但是也能勉强解决问题,如果大家有更好的办法,欢迎来指教!

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现Element Plus Carousel走马灯图片的自适应,你可以使用以下代码作为参考: ``` <template> <el-carousel :interval="5000" arrow="always" :height="bannerHeight + 'px'" style="border: 1px solid red;"> <el-carousel-item v-for="item in 4" :key="item"> <el-row :gutter="12"> <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" style="height:340px;margin-bottom: 20px;"> <img ref="bannerHeight" src="../image/banner1.png" alt="" @load="imgLoad" style="width: 100%"> </el-col> </el-row> </el-carousel-item> </el-carousel> <div id="test-div" style="border: 5px solid red;background-color: antiquewhite;">当前高度:{{bannerHeight}}</div> </template> <script> export default { data() { return { bannerHeight: 0, }; }, methods: { imgLoad() { const imgElement = this.$refs.bannerHeight; this.bannerHeight = imgElement.clientHeight; }, }, }; </script> ``` 这段代码中,我们使用`imgLoad`方法监听图片加载事件,通过`this.$refs.bannerHeight`获取图片元素的实际高度,然后将该高度赋值给`bannerHeight`变量。最后,在`el-carousel`的`:height`属性中使用`bannerHeight`作为高度值,实现了图片的自适应效果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [【最简便方法】element-plus/element-ui走马灯配置图片以及图片自适应](https://blog.csdn.net/m0_62742402/article/details/127837417)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [element-ui走马灯实现图片自适应](https://blog.csdn.net/qq_40976321/article/details/104513316)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值