在html和css中的引用svg(一)

问题:如何让 DIV 中的svg垂直居中?

HTML 代码:

<div class="content"><svg ...> ... </svg></div>

CSS代码:

.content svg { vertical-align: middle;}

实用扩展:如何让 DIV 中的内容垂直居中?

1、首推 Flex 弹性布局

CSS 属性 flex 规定了弹性元素如何伸长或缩短以适应 flex 容器中的可用空间。假设有下面的 HTML 代码:

<div id="content">居中显示</div>

那么我们可以编写CSS代码:

#content{

display: flex;

justify-content: center;(水平居中)

align-items: center;(垂直居中)

}

2、行高(line-height)法

如果要垂直居中的只有一行或几个文字,那它的制作最为简单,只要让文字的行高和容器的高度相同即可,比如:

p{

height:30px;

line-height:30px;

width:100px;

overflow:hidden;

}

这段代码可以达到让文字在段落中垂直居中的效果。

问题:css如何让< p/> 或其他标签与< svg/>在同一行显示?

用一个具有display: flex;属性的div来包括它们

HTML 代码:

<div class="content"><p> ... </p><svg ...> ... </svg></div>

CSS代码:

.content { display: flex;}

可以直接在 CSS 中直接使用 SVG:

.box {

background: url('data:image/svg+xml;utf8,<svg ...> ... </svg>');

}

不需要 Base64 转换...当然会有一些浏览器无法理解这种语法。

考虑到浏览器兼容性,用作背景图片时,建议将 SVG 编码为 Base64(或转义特定字符):

background-image: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjAwIiBoZWlnaHQ9IjIwMCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48dGV4dCB4PSI1MCUiIHk9IjUwJSIgZm9udC1zaXplPSIzMCIgZmlsbD0iI2EyYTliNiIgZmlsbC1vcGFjaXR5PSIwLjMiIGZvbnQtZmFtaWx5PSJzeXN0ZW0tdWksIHNhbnMtc2VyaWYiIHRleHQtYW5jaG9yPSJtaWRkbGUiIGRvbWluYW50LWJhc2VsaW5lPSJtaWRkbGUiIHRyYW5zZm9ybT0ncm90YXRlKC00NSwgMTAwIDEwMCknPuawtOWNsOaWh+WtlzwvdGV4dD48L3N2Zz4=");

问题:svg 图标无法铺满外部盒子的问题

//在svg 源文件的svg 头文件 加入 preserveAspectRatio="none meet"

<?xml version="1.0" encoding="UTF-8"?>

<svg width="319px" height="76px" viewBox="0 0 319 76" version="1.1" xmlns="http://www.***/2000/svg" xmlns:xlink="http://www.***.org/1999/xlink" preserveAspectRatio="none meet">

即可实现svg自适应外部盒子宽高

问题:svg 图标颜色设置不生效

调试中发现元素的颜色始终为黑色,但我已经将其颜色更改为自定义颜色(例如蓝色)。 通过添加 style="fill:#2C30FF",但没效果,不显示我设置的颜色。

解决:"#"是URL中的保留字符,您需要将"#" 替换URL 编码为 %23, 如下:

background: url('data:image/svg+xml;utf-8,<?xml version="1.0" encoding="utf-8"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" ><polygon points="6,4.5 0,0 0,1.208 6,5.708 12,1.208 12,0" style="fill:%232C30FF;"/></svg>');

(通用)好用的SVG收集:

1、<svg viewBox="0 0 64 64" class="w-16 h-16 shrink-0" xmlns="http://www.w3.org/2000/svg"><circle cx="32" cy="32" r="32" fill="#1238BF" fill-opacity="0.2"></circle><circle cx="32" cy="32" r="20" fill="#1238BF"></circle><path fill-rule="evenodd" clip-rule="evenodd" d="M29.4428 36.2766L39.8391 24.5044L41.2445 25.7455L29.5627 38.9734L23.2302 32.9722L24.52 31.6112L29.4428 36.2766Z" fill="#fff"></path></svg>

2、<svg viewBox="0 0 64 64" class="w-16 h-16 shrink-0" xmlns="http://www.w3.org/2000/svg"><circle cx="32" cy="32" r="32" fill="#E53A3A" fill-opacity="0.2"></circle><circle cx="32" cy="32" r="20" fill="#E53A3A"></circle><path d="M26 26L38 38" stroke-width="2" stroke-linecap="square" stroke="#fff"></path><path d="M38 26L26 38" stroke-width="2" stroke-linecap="square" stroke="#fff"></path></svg>

相关推荐
糕冷小美n6 小时前
elementuivue2表格不覆盖整个表格添加固定属性
前端·javascript·elementui
小哥不太逍遥6 小时前
Technical Report 2024
java·服务器·前端
沐墨染6 小时前
黑词分析与可疑对话挖掘组件的设计与实现
前端·elementui·数据挖掘·数据分析·vue·visual studio code
anOnion6 小时前
构建无障碍组件之Disclosure Pattern
前端·html·交互设计
threerocks6 小时前
前端将死,Agent 永生
前端·人工智能·ai编程
问道飞鱼7 小时前
【前端知识】Vite用法从入门到实战
前端·vite·项目构建
爱上妖精的尾巴7 小时前
8-10 WPS JSA 正则表达式:贪婪匹配
服务器·前端·javascript·正则表达式·wps·jsa
Aliex_git9 小时前
浏览器 API 兼容性解决方案
前端·笔记·学习
独泪了无痕9 小时前
useStorage:本地数据持久化利器
前端·vue.js
程序员林北北9 小时前
【前端进阶之旅】JavaScript 一些常用的简写技巧
开发语言·前端·javascript