原生js实现图片放大缩小计时器效果


Posted in Javascript onJanuary 20, 2017

知识要点

var fn=setInterval(function(){},1000)

每隔1秒执行一次函数

clearInterval(fn)

清除计时器

判断当图片放大缩小到固定大小时,清除计时器

完整代码

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>demo</title>
<style>
body,h1,h2,h3,h4,h5,h6,hr,p,blockquote,dl,dt,dd,ul,ol,li,pre,form,fieldset,legend,button,input,textarea,th,td{margin:0;padding:0;}
body,button,input,select,textarea{font:12px/1.5 tahoma,arial,\5b8b\4f53;}
h1,h2,h3,h4,h5,h6{font-size:100%;}
address,cite,dfn,em,var{font-style:normal;}
code,kbd,pre,samp{font-family:courier new,courier,monospace;}
small{font-size:12px;}
ul,ol{list-style:none;}
a{text-decoration:none;}
a:hover{text-decoration:underline;}
sup{vertical-align:text-top;}
sub{vertical-align:text-bottom;}
legend{color:#000;}
fieldset,img{border:0;}
button,input,select,textarea{font-size:100%;}
table{border-collapse:collapse;border-spacing:0;}
.clear{clear: both;float: none;height: 0;overflow: hidden;}
</style> 
</head> 
<body>
<div style="width:400px;margin:0 auto;">
 <img src="http://img.mukewang.com/53577ee900016c2102080260.jpg" id="myImage" /><br>
 <input type="button" id="max" value="放大" />
 <input type="button" id="min" value="缩小" />
</div>
<script type="text/javascript">
function pic_max(){
 var maxBtn=document.getElementById("max");
 var minBtn=document.getElementById("min"); 
 maxBtn.onclick=function(){
 max();
 }
 var img=document.getElementById("myImage");
 var maxHeight=img.height*2;
 var maxWidth=img.width*2;
 function max(){
 var endHeight=img.height*1.3;
 var endWidth=img.width*1.3;
 var maxTime=setInterval(function(){
 if(img.height<endHeight&&img.width<endWidth){
  if(img.height<maxHeight&&img.width<maxWidth){
  img.height=img.height*1.05;
  img.width=img.width*1.05;
  }else{
  alert("图片已经是最大值了")
  clearInterval(maxTime);
  }
 }else{
  clearInterval(maxTime);
 }
 },20);
 }
 minBtn.onclick=function(){
 min();
 }
 var img=document.getElementById("myImage");
 var minHeight=img.height*0.5;
 var minWidth=img.width*0.5;
 function min(){
 var overHeight=img.height*0.7;
 var overWidth=img.width*0.7;
 var minTime=setInterval(function(){
 if(img.height>overHeight&&img.width>overWidth){
  if(img.height>minHeight&&img.width>minWidth){
  img.height=img.height*0.95;
  img.width=img.width*0.95;
  }else{
  alert("图片已经是最小值了")
  clearInterval(minTime);
  }
 }else{
  clearInterval(minTime);
 }

 },20);
 }
}
window.onload=function(){
 pic_max();
}
</script> 
</body> 
</html>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
JS中字符问题(二进制/十进制/十六进制及ASCII码之间的转换)
Nov 03 Javascript
jquery实现html页面 div 假分页有原理有代码
Sep 06 Javascript
Javascript 拖拽雏形中的一些问题(逐行分析代码,让你轻松了拖拽的原理)
Jan 23 Javascript
jQuery获取this当前对象子元素对象的方法
Nov 29 Javascript
BootStrap的两种模态框方式
May 10 Javascript
详解Javascript获取缓存和清除缓存API
May 25 Javascript
node-sass安装失败的原因与解决方法
Sep 04 Javascript
通过源码分析Vue的双向数据绑定详解
Sep 24 Javascript
Vue实例的对象参数options的几个常用选项详解
Nov 08 Javascript
原生javascript中this几种常见用法总结
Feb 24 Javascript
vue Cli 环境删除与重装教程 - 版本文档
Sep 11 Javascript
vue 通过 Prop 向子组件传递数据的实现方法
Oct 30 Javascript
详解基于angular路由的requireJs按需加载js
Jan 20 #Javascript
原生js实现新闻列表展开/收起全文功能
Jan 20 #Javascript
Vue.js实现表格动态增加删除的方法(附源码下载)
Jan 20 #Javascript
node.js与C语言 实现遍历文件夹下最大的文件,并输出路径,大小
Jan 20 #Javascript
微信小程序通过api接口将json数据展现到小程序示例
Jan 20 #Javascript
BootStrap栅格系统、表单样式与按钮样式源码解析
Jan 20 #Javascript
Vue开发过程中遇到的疑惑知识点总结
Jan 20 #Javascript
You might like
PHP5中的this,self和parent关键字详解教程
2007/03/19 PHP
PHP多线程抓取网页实现代码
2010/07/22 PHP
Apache中php.ini的设置方法
2013/02/28 PHP
深入php多态的实现详解
2013/06/09 PHP
PHP类型约束用法示例
2016/09/28 PHP
javascript tips提示框组件实现代码
2010/11/19 Javascript
javascript表单验证使用示例(javascript验证邮箱)
2014/01/07 Javascript
jquery.Ajax()方法调用Asp.Net后台的方法解析
2014/02/13 Javascript
自定义刻度jQuery进度条及插件
2015/09/02 Javascript
AngularJs  Using $location详解及示例代码
2016/09/02 Javascript
js 动态生成json对象、时时更新json对象的方法
2016/12/02 Javascript
JavaScript创建对象_动力节点Java学院整理
2017/06/27 Javascript
Vue实现带进度条的文件拖动上传功能
2018/02/23 Javascript
JavaScript模块管理的简单实现方式详解
2019/06/15 Javascript
js判断密码强度的方法
2020/03/18 Javascript
vue动态加载SVG文件并修改节点数据的操作代码
2020/08/17 Javascript
为什么推荐使用JSX开发Vue3
2020/12/28 Vue.js
windows下安装python paramiko模块的代码
2013/02/10 Python
安装Python和pygame及相应的环境变量配置(图文教程)
2017/06/04 Python
Python 将RGB图像转换为Pytho灰度图像的实例
2017/11/14 Python
Python OpenCV之图片缩放的实现(cv2.resize)
2019/06/28 Python
Python Des加密解密如何实现软件注册码机器码
2020/01/08 Python
tensorflow模型保存、加载之变量重命名实例
2020/01/21 Python
150行python代码实现贪吃蛇游戏
2020/04/24 Python
python如何进入交互模式
2020/07/06 Python
python接入支付宝的实例操作
2020/07/20 Python
python 实现全球IP归属地查询工具
2020/12/18 Python
彪马西班牙官网:PUMA西班牙
2019/06/18 全球购物
大学新生军训个人的自我评价
2013/10/03 职场文书
CAD制图人员的自荐信
2014/02/07 职场文书
幼儿园运动会加油词
2014/02/14 职场文书
合作意向书格式及范文
2014/03/31 职场文书
环卫工作个人总结
2015/03/04 职场文书
高校自主招生教师推荐信
2015/03/23 职场文书
2015年办税服务厅工作总结
2015/07/23 职场文书
Python机器学习之底层实现KNN
2021/06/20 Python