继续送假期干货——响应式图片工具smartImg

中午看《众妙之门》看到一个响应式图片处理工具(点此查看)的介绍,然后就心血来潮想着不妨自己写一个基于JQ的吧,于是就又有了这么一个干货给大家。

smartImg 的全部文件可以从我的Github上下载,其实它非常小巧,去掉注释一共也就40行,之所以这么轻便,JQ也是帮了大忙。

应用场景

我们在搭建响应式页面时,对于图片的处理或多或少都有些烦躁,例如我们希望在某个屏宽的环境下显示某一张图片,在另一个屏宽的环境下则显示为另一张图片。

这种做法对于用户体验是比较重要的,常规建议是用户用大屏幕设备访问我们页面时,图片显示为大分辨率的;若用户使用小屏幕的移动设备访问我们页面时,依旧加载大尺寸的图片显然是很不妥当的做法,这样太吃用户流量,也影响加载速度。

我们的确可以用一个设置有background的容器来替代图片,然后在css media query中定义不同屏宽范围下该容器背景所对应的地址,但这种写法较为繁琐、不利维护和seo(当然它的效率会高一些)。

smartImg为解决这个问题提供了方案。

使用方式

在页面引入了jQuery和smartImg文件之后,在需要响应的<img>标签里添加 s-src="图片地址1 屏宽1,图片地址2 屏宽2, ..., 图片地址n 屏宽n" ,若屏宽参数没写则默认为0。

如下示例:

<img s-src="img/large.jpg 900,img/huge.jpg 1100,img/small.jpg" />

它表示当屏幕宽度大于1100px时显示img/huge.jpg,当屏幕宽度小于1100px但大于900px时显示img/large.jpg,其它更小屏幕宽度时则显示img/small.jpg。

当然,如果图片地址前缀是一样的,我们还可以加上s-prefix属性:

<img s-prefix="img/" s-src="large.jpg 900,huge.jpg 1200,middle.jpg 650,small.jpg 0" />

smartImg也为页面动态图片提供方案,在图片动态地新增后执行 $.smartImg() 方法即可。

虽然初衷是将其用于移动页面,但smartImg也可用于PC页面,支持屏幕大小缩放事件。

Demo

<!DOCTYPE html>
<html><head><meta http-equiv="Content-type" content="text/html; charset=utf-8"><meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no" /><title>Demo</title><style type="text/css">html,body{margin:0;padding:0;}div{position:relative;margin:20px auto;width: 90%; }.img1{width: 100%;}.img2{width: 100%;}</style></head><body><div><img class="img1" s-prefix="img/" s-src="large.jpg 900,huge.jpg 1200,middle.jpg 650,small.jpg 0" /><img class="img2" s-src="img/large2.jpg 900,img/huge2.jpg 1100,img/small2.jpg" /></div><script src="jq.js"></script><script src="smartImg.js"></script></body>
</html>

效果:

更具体的体验请下载 smartImg 后自行运行demo.html来查看。

共勉~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/299067.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一顿家庭火锅让本不富裕的家庭雪上加霜......

1 从此再也没有人相信你曾是个双眼皮▼2 在家吃火锅让一个本不富裕的家庭雪上加霜▼3 大型翻车现场▼4 各位大爷大伯&#xff0c;我先干了招待不周&#xff0c;还望海涵▼5 老外为了防止用手摸脸导致传染发明出来的新方法 ......但这东西难道不是宠物那啥用的吗&#xff1…

JAVA中pin什么意思_java语言中的多态概述

多态&#xff1a;一个对象相应着不同类型多态在代码中的体现&#xff1a;父类或接口的引用指向其子类对象。多态的优点&#xff1a;提高了代码的扩展性&#xff0c;前期定义的代码能够使用后期的内容。多态的弊端&#xff1a;前期定义的内容不能使用后期子类中定义的特有内容。…

过滤非法字符

在最近的项目中自己写了一段处理过滤非法字符的函数 原理: &#xff11;:首先判断页面的提交方式只有在&#xff50;&#xff4f;&#xff53;&#xff54;的情况下才进行过滤非法字符 &#xff12;:将所以&#xff46;&#xff4f;&#xff52;&#xff4d;表单中的数据保存到…

ASP.NET Core 修改开源协议为MIT,.NET全平台 MIT协议开源了

2021年7月23日&#xff0c;.NET开发团队完成了所有的.NET平台的相关框架的MIT协议更改&#xff0c;我们可以通过 https://github.com/dotnet/aspnetcore/issues/18873 看到详细的修改提交&#xff0c;这个协议修改里面主要有2点&#xff0c;具体可以看 https://github.com/dotn…

耳机没有声音

一 硬件二 驱动三 服务四 设置设置问题 1.应该是电脑里面的声道&#xff0c;扬声器 里面有声道设置。点击喇叭 ——打开音量控制——扬声器音量&#xff0c;&#xff0c;里面左右啊 什么的搞搞就好了 2.禁止前面板插入

C++入门【14-C++ 指向数组的指针】

您可以先跳过本章&#xff0c;等了解了 C 指针的概念之后&#xff0c;再来学习本章的内容。 如果您对 C 指针的概念有所了解&#xff0c;那么就可以开始本章的学习。数组名是指向数组中第一个元素的常量指针。因此&#xff0c;在下面的声明中&#xff1a; double runoobAarray…

InstallSield更新包快速入门文档----感谢原作者ㄣ齊¨彡仯乄的无私提供

本文经原作者ㄣ齊彡仯乄特许授权于海洋女神发布&#xff0c;转载请务必注明出处与链接&#xff1b;原作者ㄣ齊彡仯乄和海洋女神保留对该文的一切法律许可下的权益&#xff1b;需要发布在盈利性报刊、网站等请与原作者ㄣ齊彡仯乄或海洋女神联系. 简述 本文主要描述安装程序更新包…

太赞了:中文版开源!这或许是最经典的计算机编程教材

全世界只有3.14 % 的人关注了爆炸吧知识转自 AI 科技大本营《Think Python》是很多计算机初学者的不二入门教材&#xff0c;受到广泛好评。该书原作者是美国 Olin 工程学院的教授 Allen B. Downey&#xff0c;目前该书的原版和中文版本都已免费开源。Allen 称&#xff0c;《Thi…

jBPM专家力作——《深入浅出jBPM》

恭喜本书荣登互动网和当当网畅销排行榜&#xff01;媒体评论 “这是一本全面介绍jBPM的书&#xff0c;从基础知识到实战开发技巧&#xff0c;作者结合其实际项目开发经验&#xff0c;对国内流程的许多特色要求给出了浅显易懂的解决方案。对于想在项目中应用jBPM的初学者&#x…

java gui 移动_JavaGUI如图:当鼠标按left按钮,右边的字会移动到左边按 爱问知识人...

import t。*;import javax。swing。*;import t。Rectangle;import t。event。ActionListener;import t。event。ActionEvent;/*** Title:** Description:** Copyright: Copyright (c) 2006** Company:** author zwh* version 1。0*/public class Frame1extends JFrame {public …

WeihanLi.Npoi 1.20.0 Released

WeihanLi.Npoi 1.20.0 ReleasedIntroWeihanLi.Npoi 是一个基于 netstandard2.0 的一个 NPOI 扩展库&#xff0c;主要用于导入导出 Excel 以及CSV&#xff0c;支持通过 Fluent API 的方式来支持非常灵活的导入导出配置&#xff0c;详细使用可以参考文档介绍以及项目示例Updates最…

转:Chrome渲染分析之Timeline工具的使用

概述 这个工具真的很强大&#xff0c;Timeline工具栏提供了对于在装载你的Web应用的过程中&#xff0c;时间花费情况的概览&#xff0c;这些应用包括处理DOM事件, 页面布局渲染或者向屏幕绘制元素。Timeline可以通过事件&#xff0c;框架&#xff0c;和实时内存用量3个方面的数…

工作流与Petri net的关系

SOA中国线路图 > SOA业务流程 > 工作流与Petri net的关系工作流与Petri net的关系 2008-7-10工作流与Petri net的关系 工作流的发展过程 以前&#xff0c;信息系统是设计来支持单个任务的执行。今天的信息系统需要支持业务流程&#xff0c;其不只局限于仅仅关心任务&…

数学和物理太难?这些动图让你秒懂抽象概念

数学动图△ 从椭圆的一个焦点射出的光线总会通过另一个焦点。△ 真人版。△ 一图看懂正弦、余弦和正切什么意思。△ 圆的面积。△ 如何理解圆的面积和派的关系。△ 勾股定理演示。直角三角形的两条直角边的平方和&#xff08;两个小正方形的面积&#xff09;&#xff0c;加起来…

java typereference_记录一下jackson中TypeReference的使用

今天在看到项目中有一段代码是将string字符串转化成对象&#xff0c;需要被转化成对象的类加了TypeReference&#xff0c;随即去百度了下。TypeReference是一个抽象类&#xff0c;继承了Comparable接口。里面的Type是一歌接口。贴上代码&#xff1a;mapper.readValue(station.g…

cisco综合实验

第四章综合实验<?xml:namespace prefix o ns "urn:schemas-microsoft-com:office:office" />特效&#xff1a;[图]<?xml:namespace prefix v ns "urn:schemas-microsoft-com:vml" />第四章综合实验VTP的配置&#xff1a;S<?xml:name…

Docker小白到实战之容器数据卷,整理的明明白白

前言上一篇把常用命令演示了一遍&#xff0c;其中也提到容器的隔离性&#xff0c;默认情况下&#xff0c;容器内应用产生的数据都是由容器本身独有&#xff0c;如果容器被删除&#xff0c;对应的数据文件就会跟着消失。从隔离性的角度来看&#xff0c;数据就应该和容器共存亡&a…

U9在SQL Server上的性能优化经验(转述) — 之 行版本快照

此文根据用友的文档《基于SQL Server 2008构建SOA大型管理软件技术实践》“翻译”而成&#xff0c;非原创。在baidu上看见此文&#xff0c;觉得写的很好&#xff0c;就将原先的PPT细化一下并除去废话。 第二篇部分将的是行版本快照的隔离。 这是PPT上的图片&#xff1a; 图片上…

C++学习之路: 线程封装(基于对象编程)

引言&#xff1a; 此次我们重新封装线程&#xff0c; 采用基于对象编程的方式&#xff0c;不用于面向对象编程中重定义虚函数的方式&#xff0c;这里我们用回调函数的方式。 Thread.h 1 #ifndef THREAD_H_2 #define THREAD_H_3 4 #include <boost/noncopyable.hpp>5 #inc…

程序员崩溃的40个瞬间!!!

全世界只有3.14 % 的人关注了爆炸吧知识说到程序员&#xff0c;在外界眼里&#xff0c;他们是掌控代码的大神&#xff0c;他们是改变世界的王者。其实程序员的工作不容易&#xff0c;不信&#xff0c;就来看看程序员崩溃的各种瞬间——01公司实习生找bug02在调试时&#xff0c;…