viewer万能的可放大缩小翻转切换上下件的图片预览插件

2024-05-12 04:52

本文主要是介绍viewer万能的可放大缩小翻转切换上下件的图片预览插件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

**

一、需求是上面展示一张大图,下面一排小图可以通过小图切换上面的大图,然后点击大图可以放大预览并可以左右切换上下件预览

**
二、具体使用方式引入相关的js、css,用cdn的方式引入加载会更快些

<link href="https://cdnjs.cloudflare.com/ajax/libs/viewerjs/1.11.6/viewer.min.css" rel="stylesheet">
<script src="https://cdnjs.cloudflare.com/ajax/libs/viewerjs/1.11.6/viewer.min.js"></script>

三、具体代码如下

<!DOCTYPE html>
<html>
<head><link href="https://cdnjs.cloudflare.com/ajax/libs/viewerjs/1.11.6/viewer.min.css" rel="stylesheet">
</head>
<style>#image-gallery{width:800px;object-fit: contain;}.pic-c{display: flex;align-items: center;}.pic-item-c{display: flex;margin-top:10px;}.pic-item-c .pic-item.active, .pic-item-c .pic-item:hover{opacity: 1;}.pic-item-c .pic-item{width: 70px;height: 70px;overflow: hidden;margin-right:10px;box-shadow: 0 1px 5px rgba(34, 25, 25, .8);-moz-box-shadow: 0 1px 5px rgba(34, 25, 25, .8);-webkit-box-shadow: 0 1px 5px rgba(34, 25, 25, .8);border: 1px solid rgba(34, 25, 25, .8);opacity: 0.6;}.pic-item-c img{width:100%;height:100%;object-fit: contain;}
</style>
<body><div id="image-gallery"><!-- 显示大图 --><img id="big-image" src="https://imagecdn.chengxuan.com/images/2023a/mini-641-1.jpg"><!-- 隐藏的大图用于viewer.js预览 --><div style="display:none;"><img src="https://imagecdn.chengxuan.com/images/2023a/mini-641-1.jpg"><img src="https://www.cguardian.com/images/GD-2024-CN005/GD-2024-CN005-008-004/_lastModified1714969274000_/351_10/m.jpg"></div></div><!-- 小图列表 --><div class="thumbnail-content"><div class="pic-item-c"><!-- 循环展示多个小图 --><div class="pic-item"><img class="small-image" src="https://imagecdn.chengxuan.com/images/2023a/mini-641-1.jpg" data-big-image="https://imagecdn.chengxuan.com/images/2023a/mini-641-1.jpg"></div><div class="pic-item"><img class="small-image" src="https://www.cguardian.com/images/GD-2024-CN005/GD-2024-CN005-008-004/_lastModified1714969274000_/351_10/m.jpg" data-big-image="https://www.cguardian.com/images/GD-2024-CN005/GD-2024-CN005-008-004/_lastModified1714969274000_/351_10/m.jpg"></div></div></div><script src="https://code.jquery.com/jquery-1.10.2.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/viewerjs/1.11.6/viewer.min.js"></script>
<script>var viewer;
var currentImageIndex = 0; // 用于记录当前展示的大图索引document.addEventListener('DOMContentLoaded', function() {$(".pic-item").first().addClass('active');document.querySelectorAll('.small-image').forEach((item, index) => {item.addEventListener('click', function(event) {// 阻止默认点击行为event.stopPropagation();event.preventDefault()$(this).parent().addClass('active');$(this).parent().siblings().removeClass('active');const bigImageUrl = this.getAttribute('data-big-image');document.getElementById('big-image').src = bigImageUrl;currentImageIndex = index; // 更新当前大图索引});});var hiddenImages = document.querySelector('#image-gallery div');viewer = new Viewer(hiddenImages, {url: 'src',toolbar: {zoomIn: 1,zoomOut: 1,oneToOne: 1,reset: 1,prev: 1,play: {show: 1,size: 'large',},next: 1,rotateLeft: 1,rotateRight: 1,flipHorizontal: 1,flipVertical: 1,},hidden: function () {viewer.destroy();},viewed: function() {//viewer.zoomTo(1);  最好还是不写根据图片大小自适应否则有的大图100%放大都溢出屏幕 了viewer.zoomTo();}});document.getElementById('big-image').addEventListener('click', function() {viewer.view(currentImageIndex);viewer.show();});
});</script></body>
</html>

注意事项:因为需要点击放大的时候可以左右切换其他小图的大图,所以我们需要提前准备好列表可以设置display:none页面看不到即可

 <div id="image-gallery"><!-- 显示大图 --><img id="big-image" src="https://imagecdn.chengxuan.com/images/2023a/mini-641-1.jpg"><!-- 隐藏的大图用于viewer.js预览 --><div style="display:none;"><img src="https://imagecdn.chengxuan.com/images/2023a/mini-641-1.jpg"><img src="https://www.cguardian.com/images/GD-2024-CN005/GD-2024-CN005-008-004/_lastModified1714969274000_/351_10/m.jpg"></div></div>

这里的大图和小图可以做不同的比例图片,不然大图放大会失真,看各自的功能需求。

 toolbar: {zoomIn: 1,zoomOut: 1,oneToOne: 1,reset: 1,prev: 1,play: {show: 1,size: 'large',},next: 1,rotateLeft: 1,rotateRight: 1,flipHorizontal: 1,flipVertical: 1,},

上面的toolbar可以设置具体展示那些操作按钮隐藏哪些,更根据需求可定
效果图如下
在这里插入图片描述
如果想去掉预览时候展示图片大小的字样可以配置
.viewer-title {
display: none !important;
}

这篇关于viewer万能的可放大缩小翻转切换上下件的图片预览插件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/981657

相关文章

python版本切换工具pyenv的安装及用法

《python版本切换工具pyenv的安装及用法》Pyenv是管理Python版本的最佳工具之一,特别适合开发者和需要切换多个Python版本的用户,:本文主要介绍python版本切换工具pyen... 目录Pyenv 是什么?安装 Pyenv(MACOS)使用 Homebrew:配置 shell(zsh

VSCode开发中有哪些好用的插件和快捷键

《VSCode开发中有哪些好用的插件和快捷键》作为全球最受欢迎的编程工具,VSCode的快捷键体系是提升开发效率的核心密码,:本文主要介绍VSCode开发中有哪些好用的插件和快捷键的相关资料,文中... 目录前言1、vscode插件1.1 Live-server1.2 Auto Rename Tag1.3

Java使用Spire.Doc for Java实现Word自动化插入图片

《Java使用Spire.DocforJava实现Word自动化插入图片》在日常工作中,Word文档是不可或缺的工具,而图片作为信息传达的重要载体,其在文档中的插入与布局显得尤为关键,下面我们就来... 目录1. Spire.Doc for Java库介绍与安装2. 使用特定的环绕方式插入图片3. 在指定位

python项目环境切换的几种实现方式

《python项目环境切换的几种实现方式》本文主要介绍了python项目环境切换的几种实现方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 如何在不同python项目中,安装不同的依赖2. 如何切换到不同项目的工作空间3.创建项目

Python多任务爬虫实现爬取图片和GDP数据

《Python多任务爬虫实现爬取图片和GDP数据》本文主要介绍了基于FastAPI开发Web站点的方法,包括搭建Web服务器、处理图片资源、实现多任务爬虫和数据可视化,同时,还简要介绍了Python爬... 目录一. 基于FastAPI之Web站点开发1. 基于FastAPI搭建Web服务器2. Web服务

VS Code中的Python代码格式化插件示例讲解

《VSCode中的Python代码格式化插件示例讲解》在Java开发过程中,代码的规范性和可读性至关重要,一个团队中如果每个开发者的代码风格各异,会给代码的维护、审查和协作带来极大的困难,这篇文章主... 目录前言如何安装与配置使用建议与技巧如何选择总结前言在 VS Code 中,有几款非常出色的 pyt

利用Python将PDF文件转换为PNG图片的代码示例

《利用Python将PDF文件转换为PNG图片的代码示例》在日常工作和开发中,我们经常需要处理各种文档格式,PDF作为一种通用且跨平台的文档格式,被广泛应用于合同、报告、电子书等场景,然而,有时我们需... 目录引言为什么选择 python 进行 PDF 转 PNG?Spire.PDF for Python

Qt实现删除布局与布局切换功能

《Qt实现删除布局与布局切换功能》在Qt应用开发中,动态管理布局是一个常见需求,比如根据用户操作动态删除某个布局,或在不同布局间进行切换,本文将详细介绍如何实现这些功能,并通过完整示例展示具体操作,需... 目录一、Qt动态删除布局1. 布局删除的注意事项2. 动态删除布局的实现步骤示例:删除vboxLay

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni