首页
学习
活动
专区
圈层
工具
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

js图片手风琴效果代码

图片手风琴效果是一种常见的网页交互设计,它允许用户通过点击或滑动来展开或折叠图片,从而展示更多的内容。以下是一个简单的JavaScript实现示例,结合HTML和CSS来完成这个效果。

HTML结构

代码语言:txt
复制
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>图片手风琴效果</title>
<style>
  /* 基础样式 */
  .accordion {
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
  }
  .accordion-item {
    border: 1px solid #ccc;
    margin-bottom: 10px;
  }
  .accordion-header {
    background-color: #f1f1f1;
    padding: 10px;
    cursor: pointer;
  }
  .accordion-content {
    padding: 0 10px;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease-out;
  }
  .accordion-content img {
    width: 100%;
    display: block;
  }
</style>
</head>
<body>

<div class="accordion">
  <div class="accordion-item">
    <div class="accordion-header">图片1</div>
    <div class="accordion-content">
      <img src="image1.jpg" alt="Image 1">
    </div>
  </div>
  <div class="accordion-item">
    <div class="accordion-header">图片2</div>
    <div class="accordion-content">
      <img src="image2.jpg" alt="Image 2">
    </div>
  </div>
  <!-- 更多图片项... -->
</div>

<script>
  // JavaScript代码
  document.querySelectorAll('.accordion-header').forEach(header => {
    header.addEventListener('click', function() {
      const content = this.nextElementSibling;
      if (content.style.maxHeight) {
        content.style.maxHeight = null;
      } else {
        content.style.maxHeight = content.scrollHeight + 'px';
      }
    });
  });
</script>

</body>
</html>

代码解释

  1. HTML部分:
    • 创建了一个包含多个.accordion-item.accordion容器。
    • 每个.accordion-item包含一个标题(.accordion-header)和一个内容区域(.accordion-content)。
  • CSS部分:
    • 设置了基本的样式,包括边框、背景色等。
    • .accordion-content设置了初始的max-height为0,并且通过transition属性添加了展开和折叠的动画效果。
  • JavaScript部分:
    • 使用querySelectorAll选择所有的.accordion-header元素。
    • 为每个标题添加点击事件监听器。
    • 在点击事件中,切换相邻内容区域的max-height属性,从而实现展开和折叠的效果。

优势与应用场景

  • 优势: 用户友好,直观展示内容;节省页面空间,适合移动设备。
  • 应用场景: 产品展示页、新闻资讯、图库等需要动态展示图片内容的场合。

可能遇到的问题及解决方法

  • 动画不流畅: 确保CSS中的transition属性设置正确,且图片大小适中,避免过大导致加载缓慢。
  • 点击无反应: 检查JavaScript代码是否有语法错误,确保事件监听器正确绑定。

通过上述代码和解释,你应该能够实现一个基本的图片手风琴效果,并理解其背后的原理和应用场景。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 巧用CSS实现折叠手风琴效果

    引言 今天在CodePen[codepen.io] 上面发现了一个使用css实现的一个手风琴效果, 感觉蛮有意思的,于是自己尝试了一下,发现不是特别难, 在编码前把思路整理好,再去实现,就会发现轻松许多...并且宽和高是浏览器视口的宽高,那么我们就可以编写我们的css代码.然后手风琴的盒子相对于浏览器视口是水平垂直居中的 子元素相对父元素水平垂直居中,可以使用flex布局....关于flex 的详细讲解可以查看这篇文章,通过图片和代码的结合,很容易理解. ==> juejin.cn/post/720689…....然后我们接着来, 4张图片位于一个大盒子里面. active 类用来将图片撑开的, 后面会通过js 动态添加 和 删除 --url 是我们定义的一个css变量,这里定义的话 值就是每个图片在目录的相对路径...简化代码:事件委托可以减少代码的复杂性,因为你不需要管理多个事件监听器 const contain = document.querySelector('.contain') // 手风琴盒子

    21210

    小程序-实现折叠面板-手风琴效果

    背景 无论是在小程序还是 h5 网页,折叠菜单,手风琴是一个非常常见的效果,如今也有很多现成的 UI 组件库已经实现了这一效果的,但有时候在写原生小程序时,单单就是一个折叠菜单效果,却要引入整个 UI...库,有点得不偿失 以下就自己手动实现一个的 实例效果 ?...(长按扫码,进入识开发者页面即可体验) 具体实现 如下是wxml示例代码 <block wx:for="{{ listDatas }}" wx:key=...= index) { this.setData({ [`selected[${active}]`]: false, }); } }, }); 如上代码就可以实现手风琴的效果...然后列表的数据的名称以及要展示的内容放在一个数组listDatas中,随后,循环列表渲染 在列表中绑定点击事件,在元素上设置data属性,在事件对象中就可以获取到,最终通过setData修改数据,以达到实现手风琴的效果

    3.1K10

    原生javascript实现图片轮播效果代码

    前几天用jquery做了一个JS的图片轮播效果,现在用原生的javascript代码实现同样的功能,当练习用吧,代码写得不是很满意。...看到BlueDream在他博客上写的javascript仿QQ滑动菜单的效果,代码实在是优雅,相比较差别一下就凸显了,下次再把他代码的精髓偷过来,嘿嘿。...【原理简述】 html和css跟JQuery实现图片轮播效果里面的一样,略去。主要是几个公共函数,渐显和渐失,用闭包实现。至于主体逻辑部分,非常一般。...elem.style.filter = "alpha(opacity=" + level + ")"; } else { elem.style.opacity = level / 100; } } 复制代码...【调用方法】 //count:图片数量,wrapId:包裹图片的DIV,ulId:按钮DIV,infoId:信息栏 babyzone.scroll(count,wrapId,ulId,infoId

    3.8K80

    手写原生代码专题 | 图片拖拽效果(一)

    一、系列介绍 前端的小伙伴们,我想大多数都是颜值控吧,看到一个漂亮或新奇的效果,都想搞明白是怎么实现的吧。...二、 图片拖拽效果介绍 本篇文章,如下视频所示,界面有5个方格拖放区域,我们可以在这些区域里拖拽图片,当鼠标拖动图片时,图片周围有灰色的粗边框效果提示用户当前元素可拖动,在可放置图片的目标方格会出现白色的虚线边框并且背景色更改为黑色...复习完基础知识后,我们来开始动手实践吧,我们依次创建3个文件 index.html,style.css,script.js,然后在 index.html 文件里引入样式和脚本文件,接下来我们开始编写代码吧...1、编写HTML代码 html代码文件比较简单,我们依次创建5个div方格,并将被拖动的图片元素容器初始化放置在第一个方格内,并在元素上添加可拖动属性 draggable 值为 true,表示此元素可被拖动...border-style: dashed; } @media(max-width: 800px) { body{ flex-direction: column; } } 3、编写JS

    2.2K30

    用JavaScript 代码来做,图片切换效果!

    用原生的JS写动画效果的确是个很令人纠结的事情,倒不如直接用jQuery来写,亦或找一些jQuery插件。能力达不到的时候,为了工作进度,只能采取心有不甘的手段。...如果真的获得能力的提高,我认为还是必须去学习那些优秀的程序员写的优秀的代码。图片切换并不是很难,只不过要获得一些动画效果有些费力,由于本人数学不好,加之不努力,所以做起动画来很吃力。...动画切换要结合JS和CSS达到想要的效果。图片切换一般涉及的CSS的定位,以及JS定时器的知识。定位方式一般定时变换幻灯片的left或者 top属性,实现图片移动。...外部包裹的div是一个容器,用来包裹图片容器和切换容器。外部的大div和图片容器宽度和高度定死,overflow属性设置为hidden,防止图片溢出容器。 下面介绍JS代码如何实现幻灯效果。...当页面水平滚动的时候,需要注意的是,必须计算出所有图片的宽度和,并将这个值赋给图片容器,并将所有的图片外的li元素的float属性设置为left,否则,图片不会在同一行,并且会折行,从而失去水平滚动想要的效果

    3.4K50
    领券