Javascript:一款简易的图片切换插件
最近迷上javascript,每天不写点什么都不舒服哈~
尽管自己能力有限,还是尽自己所能写点东西出来。
实现效果:
该插件分为两种模式:循环播放模式,以及,单向播放模式
1# 没有选择播放模式时:
2# 选择循环模式的时候,当图片播放到第一页,或者最后一页的时候,直接跳到最后一页,或者第一页继续播放
3# 选择单向播放模式的时候,当播放到第一页,或者最后一页的时候,给予提醒,图片不能向前,或者向后继续播放
贴代码:
javascript部分:
var oCircle=document.getElementById('circle');
var oSingle=document.getElementById('single'); var oImg=document.getElementById('img');
var oPrevBtn=document.getElementById('prevBtn');
var oNextBtn=document.getElementById('nextBtn');
var oPageCount=document.getElementById('pageCount');
var oImgDes=document.getElementById('imgDes'); var imgCount=['0.jpg','1.jpg','2.jpg','3.jpg'];
var imgTitle=['1tree','2run','3hit','4sun']; var num=0; //提取公共执行部分
function commonFun(){
oImg.src='img/'+imgCount[num];
oPageCount.innerHTML=num+1 +'/'+imgCount.length;
oImgDes.innerHTML=imgTitle[num];
} commonFun(); //当用户没有选择播放模式时候,先提醒其选择播放模式
if (oSingle.classList.contains('btnSelect')==false && oCircle.classList.contains('btnSelect')==false ) { oNextBtn.onclick=function(){
alert("请选择图片播放模式");
} oPrevBtn.onclick=function(){
alert("请选择播放模式");
} } //开启循环播放模式 oCircle.onclick=function(){ //添加按钮选中时按钮样式变化
if (oSingle.classList.contains('btnSelect')) {
oSingle.classList.remove('btnSelect');
} oCircle.classList.add('btnSelect'); //循环播放函数主体 oNextBtn.onclick=function(){
num++; if (num>imgCount.length-1) {
num=0;
}
commonFun();
} oPrevBtn.onclick=function(){
num--;
if (num<0) {
num=imgCount.length-1;
}
commonFun();
} } //开启单向播放模式 oSingle.onclick=function(){ //添加按钮选中时按钮样式变化 if (oCircle.classList.contains('btnSelect')) {
oCircle.classList.remove('btnSelect');
} oSingle.classList.add('btnSelect'); oNextBtn.onclick=function(){
num++; if (num>imgCount.length-1) {
alert("~wow~已是最后一张,请向前播放");
num=imgCount.length-1;
}
commonFun();
} //循环播放函数主体
oPrevBtn.onclick=function(){
num--;
if (num<0) {
alert("~wow~已是第一张,请向后播放");
num=0;
}
commonFun();
} }
CSS部分:比较简单,图片的自适应显示用的flex
*{
margin: 0;
padding: 0;
} a{
text-decoration: none;
} .container{
position: relative;
margin: 0 auto;
width: 400px;
height: 400px;
font-size: 13px;
overflow: hidden;
background-color: #333;
display: -webkit-flex;
display: flex;
align-items: center;
} .btnBox{
width: 400px;
height: 44px;
line-height: 44px;
margin: 25px auto;
background-color: #eee;
} .btn {
float: left;
width: 49.9%;
height: 100%;
border: 0;
outline: 0;
background-color: #eee;
border-left: 1px solid rgba(0,0,0,0.15);
} .btn:first-child{
border-left: 0;
} .btnSelect{
background-color: #00bb9c;
color: #fff;
} .singleSelect{ background-color: #00bb9c;
color: #fff;
} .imgStyle{
max-width: 100%;
} .prev,.next{
position: absolute;
top:180px;
width: 40px;
height: 40px;
line-height: 40px;
text-align: center;
background-color: rgba(0,0,0,0.6);
font-size: 18px;
font-family: cursive;
color: #fff;
} .prev{
left:0;
} .next{
right: 0;
} .pageCount,.imgDes{
position: absolute;
left:0;
width: 100%;
height: 36px;
line-height: 36px;
text-align: center;
background-color: rgba(0,0,0,0.3);
color: #fff;
} .pageCount{
top: 0;
} .imgDes{
bottom: 0;
}
HTML部分:
<head>
<meta charset="utf-8">
<title>图片切换</title>
<style type="text/css"> </style>
</head>
<body> <div class="btnBox">
<button class="btn" id="circle">循环播放</button>
<button class="btn" id="single">单向播放</button>
</div> <div class="container"> <img src="" class="imgStyle" id="img">
<div class="pageCount" id="pageCount">正在加载页数...</div>
<a class="prev" id="prevBtn" href="javascript:void(0)"><</a>
<a class="next" id="nextBtn" href="javascript:void(0)">></a>
<div class="imgDes" id="imgDes">正在加载图片描述...</div> </div> </body>
Javascript:一款简易的图片切换插件的更多相关文章
- 推荐几款jquery图片切换插件
一.前言 毕业季到了,大家都在匆匆忙忙的记录大学里最美好的时光,照片中各种花式.各种姿势都涌现出来了.这么多的照片怎么展示出来给自己的好友看呢?有人选择做成视频,有人选择ps之后做成图片集,而我选择利 ...
- jQuery图片切换插件jquery.cycle.js
Cycle是一个很棒的jQuery图片切换插件,提供了非常好的功能来帮助大家更简单的使用插件的幻灯功能 下载cycle插件并引入,此时,注意把引入它的代码放在引入jQuery主文件之后. <he ...
- 手机触屏滑动图片切换插件swiper.js
今天给大家分享一款手机触屏滑动图片切换插件swiper.js是一款swiper手机触屏滑动图片幻灯片,适合各种尺寸.效果图如下: 在线预览 源码下载 实现的代码. html代码: <div ...
- jquery图片切换插件jquery.cycle.js参数详解
转自:国人的力量 blog.163.com/xz551@126/blog/static/821257972012101541835491/ 自从使用了jquery.cycle.js,我觉得再也不用自己 ...
- zoeDylan.ImgChange 图片切换插件
墨芈深夜发布插件——图片切换 附上下载地址:http://pan.baidu.com/s/17kKF3共享天地/[墨芈 插件]zoeDylan Plugins Code JS (function ($ ...
- 介绍一款网站前台图片滚动插件之"switchable"
一.简单介绍:jQuery.Switchable是一款整合了Tabs.Slide.Scrollable等常见UI组件的jQuery插件,在这里,简答说说他的Slide.像Tabs,在Jquery-UI ...
- 应用JavaScript搭建一个简易页面图片无缝滚动效果
页面图片无缝滚动JavaScript原理:移动的区块包含图片内容,区块相对父级元素进行定位脱离文档流.再令区块的left值每隔固定的时间进行等量减少(或增大)从而实现区块的匀速运动.由于每次间隔移动的 ...
- jQuery实现多种切换效果的图片切换的五款插件
1:Nivo SliderNivoslider:丰富的图片切换效果 官方网址:https://themeisle.com/plugins/nivo-slider 查看演示:https://www.he ...
- 18款 非常实用 jquery幻灯片图片切换
1.jquery图片滚动仿QQ商城带左右按钮控制焦点图片切换滚动 jquery图片特效制作仿腾讯QQ商城首页banner焦点图片轮播切换效果,带索引按钮控制和左右按钮控制图片切换. 查看演示>& ...
随机推荐
- cocos2dx 利用CCOrbitCamera实现扑克牌翻牌效果
[cpp] view plaincopy #include "HelloWorldScene.h" #include "SimpleAudioEngine.h" ...
- 【Android】添加菜单和监听菜单方法详解
添加菜单 可以在onCreateOptionsMenu或者onPrepareOptionsMenu方法中来添加菜单 代码添加: menu.add((int groupId, int itemId, i ...
- java中不常见的keyword:strictfp,transient
1.strictfp, 即 strict float point (精确浮点). strictfp keyword可应用于类.接口或方法.使用 strictfp keyword声明一个方法时,该方法中 ...
- MAVEN Scope使用
在Maven的依赖管理中,经常会用到依赖的scope设置.这里整理下各种scope的使用场景和说明,以及在使用中的实践心得.Scope的使用场景和说明1.compile编译范围,默认scope,在工程 ...
- VirtualBox虚拟机网络设置
VirtualBox虚拟机网络设置 测试环境:物理机win10企业版本,VirtaulBox版本5.0.14,虚拟机安装Windows XP及linux系统 想实现虚拟机上网的最简单方式,修改虚拟机网 ...
- jdk-tomcat环境变量设置
1.export命令直接在shell下设置 export JAVA_HOME=/home/yn4a/jdk1.6.0_16export PATH=$JAVA_HOME/bin:$PATHexport ...
- Solr的安装
1. JDK要求 Solr 4.10 要求JDK版本必须是1.7或更高. 下载地址: http://www.apache.org/dyn/closer.cgi/lucene/solr/ 下载得到z ...
- Tarjan求极大强连通分量模板
#include<iostream> #include<cstring> #include<cstdio> #include<stack> #inclu ...
- CentOS 7 之安装篇
程序员是一个学到老的行业,因为新换一个公司,感觉也轻松了好多,自己想想还是多学一些知识吧,中国政府都要强制以每年15%的比例使用国产系统,相信Linux还是有必要学习的.因为曾经在文思做Expedia ...
- C++ Primer 5th 第6章 函数
正如第一章所说:C++的函数是一个能够完成一个功能的模块或者说是一段命名了的代码块. 如下图所示,函数可以重载,是一段实现某些功能命名了的代码. 一个完整的函数的构成有四部分: 1.返回类型 2.函数 ...