发一个自己用JS写的实用看图工具实现代码


Posted in Javascript onJuly 26, 2008

  因为某些网站把内容图片以每页显示一幅的形式呈现,而每页都有大量没用的垃圾信息(广告、新闻和无关图片),非常影响看图效率。所以写了这个,只要知道第一幅图片的URL,填在本网页里,设置一下起始和结束编号,就可以显示带有数字编号的图片了,同时还有一些常用到的贴心功能。当然,对于某些网站存放的无序图片就无能为力了。

介绍完了,下面是代码内容,希望能对JS新手们有点帮助吧(请自行把下面代码里所有的“'”替换为单引号。我对这里这个格式实在没辙了):

<SCRIPT> 
//CTRL+鼠标滚轮放大或缩小图片: 
function imgzoom(o) { 
    if(event.ctrlKey) { 
        var zoom = parseInt(o.style.zoom, 10) || 100; 
        zoom -= event.wheelDelta / 12; 
        if(zoom > 0) { 
            o.style.zoom = zoom + '%'; 
        } 
        return false; 
    } else { 
        return true; 
    } 
} 
//接收热键 
document.onkeydown=mykey; 
var IsShow=false; 
function  mykey() 
{ 
    var  key=window.event.keyCode; 
//    alert(key); 
    if (key==192){ 
        if (IsShow) showIt(); 
            else hideIt(); 
//        IsShow=!IsShow; 
    }    //45=Insert键,16=Shift,17=Ctrl,18=Alt,192=` 
    if (key==13 ) catchIt();//Enter,to display 
    if (key==186)  document.getElementById('add0').checked=!document.getElementById('add0').checked; 
} function hideIt() 
{    IsShow=true; 
    //隐藏 
//    document.getElementById('showHere').style.visibility='hidden';    //保留占用的显示面积 
    document.getElementById('showHere').style.display='none';        //回收占用的显示面积 
//    document.getElementById('imgUrlBackup').innerText=document.getElementById('thePath').value; 
//    document.getElementById('thePath').value=''; 
} 
function showIt() 
{    IsShow=false; 
    //显示 
//    document.getElementById('showHere').style.visibility="visible"; 
    document.getElementById('showHere').style.display=""; 
//    document.getElementById('thePath').value=document.getElementById('imgUrlBackup').innerText; 
} 
function catchIt() 
{ 
    ////document.write('<p><table>'); 
    showIt() 
    var sn=Number(document.getElementById('startNum').value); 
    var en=Number(document.getElementById('endNum').value); 
    var str=document.getElementById('thePath').value; 
    var IsAdd0=document.getElementById('add0').checked; 
    var lastPos; 
    var Discript='<center>按1旁边的“`”键可隐藏/显示图片区域。点击图片可在新窗口查看原图。CTRL+鼠标滚轮可放大或缩小图片。</center>'; 
    var showSth='<table>'; 
    var fn=''; 
    fn=''; 
    if (IsAdd0) 
    { 
        lastPos=str.lastIndexOf('#'); 
         str=str.replace(new RegExp('#','ig'),'0'); 
        for(var n=sn;n<=en;n++) 
        { 
            fn=str.substring(0,lastPos-String(n).length+1) + n + str.substring(lastPos+1); 
            showSth=showSth+GetImgSrc(fn); 
        } 
    } 
    else 
    { 
        for(var n=sn;n<=en;n++) 
        { 
            fn=str.replace('#',n); 
            showSth=showSth+GetImgSrc(fn); 
        } 
    } 
    showSth=showSth+'</table>'; 
//    alert(showSth); 
    document.getElementById('showHere').innerHTML=Discript+showSth+Discript; 
    //    document.refresh(); 
    IsShow=false; 
} 
function GetImgSrc(ImgUrl) 
{    //让图片载入后自动调整显示尺寸以适应屏幕,并提取文件体积信息附加到提示信息上 
    //在鼠标经过时,设置鼠标为手形状 
    //在鼠标点击时,在新窗口打开图片 
    //鼠标滚轮滚动时,触发缩放图片函数 
    //设置图片的提示信息 
    return ' <img onerror="javascript:this.style.display=\'none\';"  src="' + ImgUrl  + '" onload="if(this.width >screen.width*0.7) {this.resized=true; this.width=screen.width*0.7;DispImgInfo(this);}" onmouseover="if(this.resized) this.style.cursor='hand';" onclick="window.open(this.src);" onmousewheel="return imgzoom(this);" alt="URL:' + ImgUrl + ' 点击=在新窗口查看,CTRL+鼠标滚轮=缩放图片" >'; 
} 
//把所有图片按thesize文本框指定比例进行缩放 
function ImgZoom(Operation) { 
    var ScaleTo=document.getElementById('thesize').value/100; 
    if (Operation=="toBig") {ScaleTo=1+ScaleTo;} 
    for(var i=0;i<document.images.length;i++) 
    {    document.images[i].width=document.images[i].width*ScaleTo; 
        //不用改变高度,会自动跟随长度变化而等比变化. 
    } 
} 

//  宽:'+this.width+',高:'+this.height+','+getImgsize(this)+' 
function DispImgInfo(img) { 
    if (img.src!=null && img.src!="") 
            img.alt=img.alt + " 宽:"+img.width+",高:"+img.height+",大小:"+getImgsize(img); 
} 
function discAllimages() { 
    //getAllimages 
    for (var i=0; i<document.images.length; i++) 
    {    var img=document.images[i]; 
        if (img.src!=null && img.src!="") 
            img.alt=img.alt + " 宽:"+img.width+",高:"+img.height+",大小:"+getImgsize(img); 
    } 
} 
function getImgsize(x) { 
    var picSize=x.fileSize; 
    if (picSize>1000) picSize=Math.round(picSize/1024*100)/100+'KB'; 
    else if (picSize > 0) picSize=picSize+'字节'; 
    else picSize='未知'; 
    return picSize; 
} 
</SCRIPT> 

作者:ZhaoLiang -- 碧海情天、淹没天空的海  邮箱:thedoc01@163.com   制作时间:2006年8月 
<BR>功能:批量显示带数字编号的本地或网络图片。如 C:A##.gif 或 file:///C:/A##.gif 或 http://www.cctv.com/A3#.jpg 
<BR>说明:如图片名称是A02而非A2时,可用##指定编号的固定长度并选择“固位补零”,则不足位的会自动用0补齐) 
<BR>热键:`(~)键=显示开/关。;键=开关固位补零。图片上CTRL+鼠标滚轮=缩放图片。点击图片=在新窗口打开。HOME=篇幅较长时可返回开头。 
<HR> 
路径:<INPUT id='thePath' style="apos: " type='text'></INPUT> 
起始编号:<INPUT id='startNum' style="apos: " type='text'></INPUT> 
结束编号:<INPUT id='endNum' style="apos: " type='text'></INPUT><BR> 
<INPUT id='add0' type='checkbox'></INPUT>固位补零 
 <INPUT onclick=javascript:catchIt() type='button' value='显示之'></INPUT> 
<!--  <input type='button' id='see' onclick="javascript:showIt()" value='再显示'></input> 
--> 
<INPUT onclick=javascript:ImgZoom('toSmall') type='button' value='缩小'></INPUT> 
<INPUT onclick=javascript:ImgZoom('toBig') type='button' value='放大'></INPUT> 
缩放比例(百分之):<INPUT id='thesize' style="apos: " type='text' value=50>(回车即显示图片) 
<!--  <input type='button' onclick="javascript:discAllimages()" value="显示图片信息"> 
--> 
<HR> 
<DIV id='showHere'></DIV> 
<DIV id='imgUrlBackup' style="DISPLAY: none; apos: "></DIV> 
<SCRIPT> 
    document.getElementById('thePath').focus(); 
</SCRIPT> 
<!-- 
作者:ZhaoLiang -- 碧海情天、淹没天空的海  邮箱:thedoc01@163.com 
看显示区代码javascript:alert(document.getElementById('showHere').innerHTML); 
-->

平时也不注意整理,所以这个文件改过几个不同版本,发完了我才想起,曾经把hideIt()和showit()合并成一个函数(根据参数进行处理就行了),还有其它一些细节。因为对这里的编辑还不太熟,就不再改了,大家有兴趣自己试试吧。如果有什么建议能提供的话就更好了。

(更新:修改了一下,对于不存在的图片,自动隐藏,不占据显示空间——通过img的onerror事件进行处理。 
另外要说的,这里现在这个代码编辑器,很容易导致编辑后的内容大乱套。我花了很长时间来改正错误的替换代码,感觉比我写这个脚本工具都累。而且,里面SPAN的生成,完全没有优化,不必要的重复数量简直惊人,希望OpenSoft开发组尽快完善。)

Javascript 相关文章推荐
IE浏览器IFrame对象内存不释放问题解决方法
Aug 22 Javascript
jQuery向webApi提交post json数据
Jan 16 Javascript
浅析JS中的 map, filter, some, every, forEach, for in, for of 用法总结
Mar 29 Javascript
基于JS代码实现简单易用的倒计时 x 天 x 时 x 分 x 秒效果
Jul 13 Javascript
vue中v-model动态生成的实例详解
Oct 27 Javascript
React Native 使用Fetch发送网络请求的示例代码
Dec 02 Javascript
JS设计模式之命令模式概念与用法分析
Feb 06 Javascript
javascript性能优化之分时函数的介绍
Mar 28 Javascript
vue使用自定义指令实现拖拽
Jan 29 Javascript
微信小程序 冒泡事件原理解析
Sep 27 Javascript
原生JS无缝滑动轮播图
Oct 22 Javascript
vue style width a href动态拼接问题的解决
Aug 07 Javascript
对JavaScript的eval()中使用函数的进一步讨论
Jul 26 #Javascript
js树形控件脚本代码
Jul 24 #Javascript
js类中的公有变量和私有变量
Jul 24 #Javascript
javascript IE中的DOM ready应用技巧
Jul 23 #Javascript
css把超出的部分显示为省略号的方法兼容火狐
Jul 23 #Javascript
用JavaScript实现UrlEncode和UrlDecode的脚本代码
Jul 23 #Javascript
用js遍历 table的脚本
Jul 23 #Javascript
You might like
关于文本留言本的分页代码
2006/10/09 PHP
PHP flush()与ob_flush()的区别详解
2013/06/03 PHP
Aster vs Newbee BO5 第二场2.19
2021/03/10 DOTA
js GridView 实现自动计算操作代码
2009/03/25 Javascript
struts2 jquery 打造无限层次的树
2009/10/23 Javascript
利用jquery的获取JS文件中的字符串内容
2012/02/14 Javascript
JavaScript控制Session操作方法
2013/01/17 Javascript
js输入框邮箱自动提示功能代码实现
2013/12/10 Javascript
js 操作select与option(示例讲解)
2013/12/20 Javascript
基于Flowplayer打造一款免费的WEB视频播放器附源码
2015/09/06 Javascript
jQuery查找dom的几种方法效率详解
2017/05/17 jQuery
JavaScript模拟实现封装的三种方式及写法区别
2017/10/27 Javascript
微信小程序自定义select下拉选项框组件的实现代码
2018/08/28 Javascript
基于javascript处理nginx请求过程详解
2020/07/07 Javascript
Python 冒泡,选择,插入排序使用实例
2015/02/05 Python
Python 使用requests模块发送GET和POST请求的实现代码
2016/09/21 Python
python2.7到3.x迁移指南
2018/02/01 Python
Keras 数据增强ImageDataGenerator多输入多输出实例
2020/07/03 Python
Python3+Appium安装及Appium模拟微信登录方法详解
2021/02/16 Python
网络教育自我鉴定
2013/11/01 职场文书
远程教育心得体会
2014/01/03 职场文书
企业宣传方案
2014/03/04 职场文书
募捐倡议书
2014/04/14 职场文书
铁路安全事故反思
2014/04/26 职场文书
出国留学计划书
2014/04/27 职场文书
一体化教学实施方案
2014/05/10 职场文书
汽车广告策划方案
2014/05/31 职场文书
学习礼仪心得体会
2014/09/01 职场文书
车贷收入证明范本
2014/09/14 职场文书
学校政风行风自查自纠报告
2014/10/21 职场文书
毕业论文答辩稿范文
2015/06/23 职场文书
总经理2015中秋节致辞
2015/07/29 职场文书
祝福语集锦:给百岁老人祝寿贺词
2019/11/19 职场文书
深入解析NumPy中的Broadcasting广播机制
2021/05/30 Python
vue里使用create, mounted调用方法
2022/04/26 Vue.js
Mysql索引失效 数据库表中有索引还是查询很慢
2022/05/15 MySQL