web前端中的图片

2024-09-07 21:18
文章标签 图片 web 前端 frontend

本文主要是介绍web前端中的图片,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        开篇语: 在做web前端开发过程中,图片是避开不了的话题,合适的位置放一张合适的图片,胜过很多文字,可以是html便签img,也可以是css背景,还可以是svg生成的image,不同的图片对网站的性能和可访问性有很大的差异。接下来我们一起看一下各种图片的添加方式以及优缺点

1、img标签
  基本用法:

<img src="./cat.gif" alt=""/>

页面加载的时候,如果不设置img的宽度和高度,那么图片加载后会引起布局的移动,如果想避免这一点,可以对img设置宽高,这样图片加载前就会固定好位置,保留空间,不会引起页面的重绘

2、CSS隐藏图片
     图片可以通过CSS隐藏,但是仍然会被加载到页面中,即使设置为display:none, 也不会阻止图片的加载,img元素被认为是被替换元素, 所以我们无法控制它加载的内容。
     图片是内联元素,也是替换元素,正常的内联元素不可以设置宽高(设置了不起效果), margin左右有效上下无效,padding上下左右都有效,内联替换元素可以设置宽高, 替换元素是浏览器根据其标签的元素与属性来判断显示具体的内容
     可替换元素的展现效果不是由css来控制的,这些元素是一种外部对象,它们外观的渲染,是独立于css的,CSS可以影响可替换元素的位置,但不影响自身的内容,替换元素有img, input, textarea, select等,它们都有以下特性:

  1. 替换元素都是行内元素
  2. img的基线位于元素的下边缘,vertical-align的默认值是baseline,因此图片下方会有几个像素的空隙,而input这类可输入的文本的替换元素,基线默认是输入的文本的基线,如果设置display为inline-block,那么基线就是元素的下边缘,否则是文本的基线
  3. 替换元素的尺寸有3种:固有尺寸< html尺寸 < css尺寸,如果对img设置了高度或者宽度,则元素会按照比例展示,即使内联替换元素设置为display:block。元素也不会撑满父元素的宽度
  4. 内联元素的高度仅有行高决定,垂直方向的margin,border,padding并不影响元素实际高度,而替换元素与display:inline-block相似,替换元素垂直方向的margin,border,padding会影响行高

3、可访问性问题
     HTML图片应该将alt属性设置为有意义的描述。如果图片加载失败的时候,有没有alt属性的区别在于是否保留原来的宽高,看下面的例子:

<style>
img {width: 200px;height: 100px;border:1px solid #000;
}
</style>
<img src="./ca1t.gif"/>
<img src="./ca1t.gif" alt="加载失败" />

得到的结果是这样的:
分别没有alt和有alt
4、响应式图片
img标签的好处是可以为不同的视口展示不同的版本,有两种方式获得一组响应式的图片集

  1. srcset属性
<img src="cat.gif" srcset="buou.jpg 1x, meiduan.jpg 2x" alt=""/>

例子可以看这里,chrome好像不支持,可以使用Firefox来查看

  1. Picture元素
<picture><source srcset="yingduan.jpg" media="(min-width: 800px)" /><source srcset="buou.jpg" media="(min-width: 500px)" /><img src="cat.gif" />
</picture>

实现效果如下:
在这里插入图片描述在这里插入图片描述
5、CSS背景图片

使用方法如下:

.element {background: url('cool.jpg');
}

还可以通过媒体查询设置在不同的分辨率下显示或隐藏

@media(min-width:700px) {.element {background: url('cool-1.jpg');}
}

6、SVG
svg是一种矢量图,最大的特点是在缩放的时候不会影响图片质量,在svg中我们可以嵌入jpg/png/svg图像等,把imgae嵌入到svg中还有一个很大的特点就是用户不能点击下载图片

<svg width="200" height="200"><image href="buou.jpg" height="100%" width="100%" preserveAspectRatio="xMidYMid slice" />  
</svg>

这篇关于web前端中的图片的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1146185

相关文章

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

利用Python脚本实现批量将图片转换为WebP格式

《利用Python脚本实现批量将图片转换为WebP格式》Python语言的简洁语法和库支持使其成为图像处理的理想选择,本文将介绍如何利用Python实现批量将图片转换为WebP格式的脚本,WebP作为... 目录简介1. python在图像处理中的应用2. WebP格式的原理和优势2.1 WebP格式与传统

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

如何使用Maven创建web目录结构

《如何使用Maven创建web目录结构》:本文主要介绍如何使用Maven创建web目录结构的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录创建web工程第一步第二步第三步第四步第五步第六步第七步总结创建web工程第一步js通过Maven骨架创pytho

Java Web实现类似Excel表格锁定功能实战教程

《JavaWeb实现类似Excel表格锁定功能实战教程》本文将详细介绍通过创建特定div元素并利用CSS布局和JavaScript事件监听来实现类似Excel的锁定行和列效果的方法,感兴趣的朋友跟随... 目录1. 模拟Excel表格锁定功能2. 创建3个div元素实现表格锁定2.1 div元素布局设计2.

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框

HTML img标签和超链接标签详细介绍

《HTMLimg标签和超链接标签详细介绍》:本文主要介绍了HTML中img标签的使用,包括src属性(指定图片路径)、相对/绝对路径区别、alt替代文本、title提示、宽高控制及边框设置等,详细内容请阅读本文,希望能对你有所帮助... 目录img 标签src 属性alt 属性title 属性width/h

如何使用Haporxy搭建Web群集

《如何使用Haporxy搭建Web群集》Haproxy是目前比较流行的一种群集调度工具,同类群集调度工具有很多如LVS和Nginx,本案例介绍使用Haproxy及Nginx搭建一套Web群集,感兴趣的... 目录一、案例分析1.案例概述2.案例前置知识点2.1 HTTP请求2.2 负载均衡常用调度算法 2.

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.