手风琴-js+css

html 复制代码
<template>
  <div>
    <div class="pics">
      <ul id="picList">
        <li><a href="#"><img src="../assets/images/researchOne.webp" alt=""></a></li>
        <li><a href="#"><img src="../assets/images/researchTwo.webp" alt=""></a></li>
        <li><a href="#"><img src="../assets/images/researchThree.webp" alt=""></a></li>
      </ul>
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {};
  },
  mounted() {
    let ul = document.getElementById("picList");
    let lies = ul.children ;
    // 第一个 li 变宽:增加类 active
    lies[1].classList.add("active");
    // 查找兄弟标签函数
    let findSiblings = function(tag){
      let parent = tag.parentNode ;
      let child = parent.children ;
      let sb = [];
      for(let i = 0 ; i <= child.length-1 ; i++ ){
        if( tag !== child[i]){
          sb.push( child[i]);
        }
      }
      return sb ;
    };
    
    for( let i = 0 ; i <= lies.length-1 ; i++  ){
      lies[i].addEventListener("mouseenter",function(){
        let siblings = findSiblings(this);
        // 当前标签变宽: 增加类 active
        this.classList.add("active");
        // 兄弟标签变窄
        for(let k = 0 ; k <= siblings.length-1 ; k++ ){
          // 兄弟标签去掉 active
          siblings[k].classList.remove("active");
        }
      });
    }
  },
};
</script>

<style lang="scss" scoped>
*{
  margin: 0;
  padding: 0;
}
ul,li,ol{
  list-style: none;
}
img{
  border:none;
}
/* 公用css 结束 */
 
.pics{
  width: 1000px; /* 1个 600px,4个 100px*/
  margin-left: auto;
  margin-right: auto;
  height: 400px;
  overflow: hidden;
}
.pics ul{
  display: flex;    /* flex 布局让 li 横向排列 */
  justify-content: space-between;  /* 内容靠向两端 */
}
.pics ul li{
  width: 200px;
  height: 400px;
  position: relative;
  overflow: hidden;
  transition:all 0.4s;   /* 过渡动画 */
  flex-grow: 1;   /* 让 li 始终能占满整个 ul ,保证变化过程中 li 之间没有缝隙 */
  margin-left: 15px;
}
.pics ul li img{
  position: absolute;   /* 确保图片在 li 里显示中间部分 */
  left:50%;
  top:0;
  margin-left: -300px;
}
.pics ul li.active{    /* 有类 active li 宽度为 600px。去掉,就会恢复 100px */
  width: 600px;
}
</style>

参考:JavaScript 练手小案例:超级简单又炫酷的图片手风琴效果_图片手风琴效果 js-CSDN博客

相关推荐
fxshy几秒前
Vue 项目中 vis-network 点击节点不生效的问题排查:外层 transform 缩放导致坐标偏移
前端·javascript·vue.js
Maimai108087 分钟前
Redux Toolkit 项目落地:从 slice、thunk 到可维护的前端状态管理
前端·javascript·react.js·前端框架·reactjs
ZC跨境爬虫7 分钟前
模块化烹饪小程序开发日记 Day3:(Flask后端初始化、数据库配置与自定义日志系统搭建)
前端·javascript·数据库·后端·python·flask
ZC跨境爬虫14 分钟前
跟着 MDN 学 HTML day_64:从 object 到 iframe 的嵌入技术全面解析
开发语言·前端·javascript·ui·html·音视频
暗冰ཏོ22 分钟前
《前端动画超详细教程:CSS、JS 动画原理、实战与性能优化》
前端·javascript·css·动画
万岳科技系统开发27 分钟前
外卖跑腿配送开发搭建指南:从用户下单到配送完成全流程解析
大数据·前端·小程序
华万通信king33 分钟前
腾讯云CLB负载均衡接入实战:高并发Web服务的稳定性配置
前端·负载均衡·腾讯云
JiaWen技术圈34 分钟前
从零认识 OpenTelemetry (OTel)
运维·前端·安全
冴羽yayujs34 分钟前
GitHub 热门项目-日榜(2026-05-19)
前端·javascript·github
AIFQuant35 分钟前
JavaScript 前端集成贵金属 K 线图:10 分钟快速实现
开发语言·前端·javascript·websocket·金融·期货api