css 图片相关

展示图片

  1. 使用 <img /> 标签;
  2. ::after 和 ::before 设置图片;
  3. 鼠标 hover 自定义光标样式;
  4. border-image 自定义边框图案;
  5. list-style-image 设置列表项样式;
  6. background-image 设置背景图片;
/* 居中不重复的背景图片 */
background: url(../asset/img/logo.jpg) no-repeat center;

/* x轴重复 */
background: url(../asset/img/logo.jpg) repeat-x;

/* background 是以下属性值的缩写
    image: 背景图片 
    color: 背景颜色 
    repeat: 定义图片重复的方式 可选值 repeat-x/repeat-y/repeat/space/round/no-repeat
    size: 背景图片大小 可选值 contain/cover/百分比/具体像素
    clip: 背景图片延伸到哪个位置 可选值 text/border-box/padding-box/content-box 
    origin: 背景图片相对于哪个区域开始摆放 border-box/padding-box/content-box
    attachment: 背景图片在视口内固定还是随包含它的区块滚动 scroll/fixed/local
    position: 相对origin为图片设置初始位置  left/bottom/top/right/center/百分比/具体像素
    position-x: 设置背景图片在水平方向的位置 left/center/right/百分比/具体像素
    position-y: 设置背景图片在垂直方向的位置 top/center/bottom/百分比/具体像素
*/
div::after{
  content: url(../asset/img/logo.jpg);
}

cursor: url(../asset/img/cursor.jpg) auto;

/* border-image: source slice width outset repeat|initial|inherit; */
border: 10px solid transparent;
border-image: url(./images/logo.png) 30 30 10 round;

/* 列表项标记样式 */
list-style-image: url(./images/checked.png);

图片缩放

①纯css实现缩放

/* 方式一 */
transform: scale(.8);

/* 方式二 */
zoom: 50%;

②图片随鼠标滚轮缩放

/* html */
<img src="./images/desktop.jpg" alt="" onmousewheel="return zoom(this)" />

/* javascript */
function zoom(el) {
    var zoom = parseInt(el.style.zoom, 10) || 100;
        zoom += event.wheelDelta / 100;
        console.log(event.wheelDelta);
        if (zoom > 0) {
            el.style.zoom = zoom + '%';
        }
    return false;
}

图片填充设置

object-fit 可以设置替换元素 (<img /> <iframe>...) 的内容如何填充到容器中,在<img /> 元素中的使用如下:

object-fit: contain;

/* object-fit 包含以下几种值, 
   fill: 默认值,填充,图片填满容器,可能会改变宽高比,导致图片拉伸;
   contain: 包含,整个图片会保持宽高比展示在容器中,可能会被缩放,部分背景会空白;
   cover: 覆盖,图片保持宽高比填满容器,图片可能会被裁剪;
   none: 保持图片原尺寸和比例;
   scale-down: 等比缩小,类似依次设置了 none 和 contain,最终展示尺寸较小的那个;
*/

图片位置设置

object-position 可以设置替换元素的内容在容器中的位置,可用 left、top 等方位值控制,也可以用具体的数值表示,在<img /> 元素中的使用如下:

object-position: left top;

/* 
  object-position: 水平方向可能的值       垂直方向可能的值
  object-position: left/center/right   top/center/bottom;
  object-position: 10px 15px; 
  如果只设置了一个值,则默认另一个方向的值为 center    
  如:object-position: top; => object-position: center top;
*/

图片热区

定义:在图片中指定某个区域,当用户点击该区域内时可以链接跳转到指定页面。
应用场景:中国地图图片点击具体的省份跳转到各省对应的官网。
创建图片热区:

/* 
  <area shape="rect/circle/poly" href="" coords="" target="_blank/_parent/_self/_top"> 
  shape: 规定区域的形状;  
  href: 目标 url;  
  coords: 坐标; shape="rect" => x1,y1,x2,y2; shape="circ" => x,y,radius
  target: 在何处打开目标 url
*/
<img src="../asset/images/china.jpg" usemap="#mapname"/>
<map name="mapname" id="mapname">
    <area shape="rect" href="" coords="0,0,50,50"/>
</map>

滤镜属性

filter 属性可以调节元素的视觉效果,如设置图片灰度、透明度、饱和度等

filter: none | 默认
        blur(px) | 高斯模糊
        brightness(%) | 亮度
        contrast(%) | 对比度
        drop-shadow() | 阴影
        grayscale(%) | 灰度
        hue-rotate() | 色相旋转
        invert(%) | 反相
        opacity(%) | 透明度
        saturate(%) | 饱和度
        sepia(%) | 深褐色
        url();

3 像素bug

描述:img 标签渲染之后下方会出现几个像素(谷歌是 4px, 火狐 3.5px)的空白;
原因:img 是行内元素,默认display:inline; 它与文本的默认行为类似,下边缘是与基线对齐,而不是贴紧容器下边缘,所以会有几像素的空白;
解决办法:
把 img 设置为display: block;
给 img 和其父元素都设置 vertical-align: top;让其 top 对齐而不是 baseline 对齐;
给 img 父元素设置 line-height: 0;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容