个人电脑里存了不少适合手机欣赏的图片,但是放手机里看是件很占据资源的事。鉴于家里有一台电脑经常开着,正好用来做家庭局域网共享,于是笔者就设想通过一种比较简单环保的思路。通过手机访问电脑内的图片。
首先是本地站点搭建:win+R输入mmc打开控制台,文件-添加/删除管理单元,Internet信息服务。添加确定,右侧基本信息,新建网站-把路径改了。设定一个端口号,手机浏览器就可以输入 电脑局域网ip:端口号 就可以连上去了。
接下来问题来了,一个个点击查看然后关闭图片是一件更不环保的事。何不做一个网页访问呢?最简单的就是选项卡-轮播图的模式。鉴于bootstrap的易适配性,就直接用它吧。
一. 初始化设置:
按钮组(ul-li-button)(太长,所有overflow hidden,需要滑动显示),按钮组是根据实际情况用DOM生成的,进入页面默认显示第一页红色高亮显示。
跳转按钮:一文本输入框,一个button风格的input
美图展示区
二. 页面主要实现三个功能,每个功能要实现三类相似的效果:
1. 手指点击页面可以自动切换
左右区域被点击
思路,做两个透明的绝对定位div一左一右,覆盖img层上方。点击时可以触发事件:
(1)按钮组颜色变化
(2)按钮组滑动
(3)图片切换
这里有个谁控制谁的问题,需要选取点击一瞬间的红色按钮,然后变变蓝,下一个(上一个)变红。
(ul-li-button)体系中,按钮组滑动距离应该是当前的基础上前进或后退一个li的宽度单位。但是自适应的按钮个位数和十位数宽度不同。需要分类讨论之。
图片根据变化后红色按钮内的序号改变显示的图片。
所以是序列按钮控制所有功能
2.点击按钮页面切换
事件——序列按钮被点击
(1)点击按钮颜色变化——被点击的按钮变红,其它变蓝——不难
(2)按钮组滑动目标位置——用的是当前按钮的left值,加上少算ul-lipadding的15——就算出了当前button相对于ul的偏移。然后,把此偏移作为ul相对于显示区的偏移值。(如果愿意,可以加上一个值,让按钮看起来居中)
(3)图片切换,根据变化后红色按钮内的序号改变显示的图片。
此过程1依然是序列按钮控制所有功能。
3.输入跳转
事件——跳转按钮被点击
(1)按钮变色,根据输入框内的value值,用原生js把该含有该序号的按钮选出来。变红
(2)按钮组滑动——跟前面一样
(2)图片切换,跟前面一样。
此过程是输入框控制页面的所有功能。
根据这个思想,大致的功能就实现了。
三 .有几个原则:
(1)动画控制:手持设备的特性允许用户以很快的手速点击屏幕,频繁地触发事件导致按钮不能停止。可以用判断动画函数来阻止运行。但是这样做让页面生硬。可以考虑用淡出——改变图片路径(延迟执行)——淡入的方式,及解决了快手速用户问题,也能在一定程度上提升柔和感,
(2)极限控制,当第一页和最后一页时,应阻止用户再操作。
(3)图片为了网页应该做一定的修改,本例采用的图片命名为xxx (1) ,xxx (2)。。。。的方式,因为有一个流水号所以DOM操作起来很方便。
四. 进一步应用
写了那么多代码,只用在一个套图页面上面,就太不环保了。所以把它们封装为函数。传入两个参数:url 和 imgNum分别代表图片路径和套图数量。
url是一个字符串,必须满足下面要求:
图片文件名必须夹杂 “(流水号)”,对文件夹名等无要求,比如 “文静/wenjing().jjpg” 系列流水号由js生成。所以不用写。
实现手段是slice()方法。
五.问题
首次加载时动画显示滞后,是因为需要时间下载所致,可以通过适当延长动画时间。在家庭共享环境下,可以忽略这个问题。
可能存在因为bootstrap特性,所以有若干自定样式的表现不符合设计的规范。
效果图:(适配ip6)
demo地址:(建议手机观看)
代码清单html
<!DOCTYPE html> <html lang="zh-cn"> <head> <!--页面编码 --> <meta charset="UTF-8"> <!--低版本浏览器模拟渲染--> <meta content="width=device-width, initialscale= 1, maximumscale=1, user-scalable=no"> <meta content="width=deviece-width,initial-scale=1"> <!--支持国产浏览器的高速渲染--> <meta content="Webkit"> <!--在此进行SEO设置:作者、关键词、描述--> <meta content="djtao"> <meta content="djtao"> <meta content="djtao"> <title>Ugirl</title> <!--bootstrap--> <!--以下两个js插件用于在IE8及以下支持H5元素查询的,如不用可移除 --> <!--[if lt IE 9]> <script src="https://www.jb51.net/scripts/html5.min.js"></script> <script src="https://www.jb51.net/scripts/respond.min.js"></script> <![endif]--> <!--bootstrap样式文件 --> <link href="https://www.jb51.net/bootstrap/css/bootstrap.css"> <!--自定义样式文件 --> <link href="https://www.jb51.net/styles/css.css"> <!--基于jQuery的脚本文件 --> <script src="https://www.jb51.net/scripts/jquery.min.js"></script> <!-- bootstrap的jq插件 --> <script src="https://www.jb51.net/bootstrap/js/bootstrap.min.js"></script> <!--自定义脚本文件 --> <script src="https://www.jb51.net/scripts/js.js"></script> </head> <body> <header> <h1>Ugirl <small>专业的秘密</small></h1> </header> <div> <div> <ul></ul> </div> <div> <form> <div> <div><input col="2" type="text"></div> <div><input type="button" value="jump"> </div> </form> </div> </div> </div> <div> <div> <div></div> <div></div> <img src="img/wenjing/wenjing (1).jpg"> </div> </div> </body> </html>
css