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

相关文章

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat

使用Python实现无损放大图片功能

《使用Python实现无损放大图片功能》本文介绍了如何使用Python的Pillow库进行无损图片放大,区分了JPEG和PNG格式在放大过程中的特点,并给出了示例代码,JPEG格式可能受压缩影响,需先... 目录一、什么是无损放大?二、实现方法步骤1:读取图片步骤2:无损放大图片步骤3:保存图片三、示php