博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HTML5实践 -- 使用css装饰你的图片画廊
阅读量:5055 次
发布时间:2019-06-12

本文共 1378 字,大约阅读时间需要 4 分钟。

  转载请注明原创地址:

 

  本节课我们将介绍,如何使用css在不修改图片源的前提下装饰你的图片画廊。这里用到的技巧也很简单,就是在图片之前创建一个<span>,并在span上使用background-image生成一个遮罩的效果。这种方式既简单又灵活,demo中介绍了20多种样式,大家可以参看。

 

  demo预览地址:

  demo下载地址:

 

  这种css技巧带来的好处

  • 节约时间 — 你不需要在photoshop中创建图片模板,然后为每张图片生成独立文件。
  • 保留原始图片源 — 我们不用担心日后需要更换图片主题的时候,没有原图片。因为我们根本没有修改他。
  • 相当的灵活 — 你只需要调整css就能换一个完全不同的样式。
  • 在任何站点都能工作 — 这个css技巧在任何站点,任何图片大小下都适用。
  • 解决浏览器兼容问题 — 通过了大多数浏览器的测试 (Firefox, Safari, Opera, 甚至包括行为怪异的IE6)。

 

  基本概念

  我们需要在包裹img的div中创建一个span元素,在他上面适用background-image来产生遮罩的效果。如果你不喜欢插入一个空的span标签,我们可以使用javascript来动态生成他,之后我们会介绍到。下面的代码揭示了他如何工作。

  对于css代码,我们需要注意的是,需要为div设置position:relative,为span设置 position:absolute。这样你就可以通过为span设置top和left属性,来任意摆布他在div中的位置了。

 

  IE PNG hack

  为了能让透明的png图片在ie6中工作,我们需要使用到强大的  hack。下载 iepngfix.htc 文件,并在页面<head>标签中添加如下代码。

 

  外观

  我们只需要修改指定span元素的css,就能实现不同样式的变化。查看demo源代码,你会发现其中的奥秘。

 

  jquery解决方案

  如果你不喜欢在页面中直接添加空的span标签,可以使用下面的jquery代码,实现span的动态添加。

 

  #1. 简单画廊

  让我们使用之前介绍的技术,来创建画廊吧。

  #1b. 迷你icon

  这个例子为了展示了,如何在图片上面放置不同的icon。我们需要为span标签设置不同的css class 名称。

 

  #2. 带文字的图片

  该例子为了展示了如何创建带文字连接的画廊。

  #2b. 弹出文字

 

  #3. 迷你纸夹

 

  #4. 软木板画廊

  sIFR版本(文字替换)

  在这个版本中借助 , 实现将em中的文字替换为手写体。

  #4b.胶带效果

 

  #5.黑框艺术画廊

  #5b.金边艺术画廊

 

  #6.水彩效果

 

  sIFR版本

 

  #7.高光效果

 

  #8.木板画廊

  最后我们展示如何使用background-image来实现木板的效果。

 

  最后评论

  我们可以看到这种css技巧相当的灵活,他极具创造性,他将图片和css有机的结合在了一起。你也可以使用这种方式,创建自己不同风格的画廊。

 

  原文地址:

 

转载于:https://www.cnblogs.com/softlover/archive/2012/11/25/2779890.html

你可能感兴趣的文章
SQLServer更改用户定义的数据库角色
查看>>
Linux下环境变量配置方法梳理(.bash_profile和.bashrc的区别)
查看>>
pygame系列_箭刺Elephant游戏
查看>>
linux 查看版本
查看>>
CentOS7.0下载各版本说明 新增Everything版
查看>>
s:iterator巧妙控制跳出循环
查看>>
上海启动5G试用!104页PPT,为你深度解析5G终端的创新和机遇
查看>>
[bzoj3289]Mato的文件管理
查看>>
面向对象第三单元总结
查看>>
Mysql 用户root密码重置
查看>>
0. 数据库运维做些什么
查看>>
数据库基本知识(一)-基本概念
查看>>
hihoCoder [Offer收割]编程练习赛83 D 生成树问题
查看>>
seajs使用记录
查看>>
凉风起天末
查看>>
给sftp创建新用户、默认打开和限制在某个目录
查看>>
C++入门经典-例4.4-循环嵌套之求n的阶乘
查看>>
【cs231n】线性分类笔记
查看>>
JSONP解决ajax跨域问题
查看>>
实验七
查看>>