您现在的位置是:首页 > 数码 > 

vue+element

2025-07-27 02:33:10
vue+element 因为element-ui内置的小图标非常有限,所以有时候,我们需要自定义或引入第三方图标库。 先介绍下阿里巴巴矢量图标库iconfont: 这个截图只显示了第一行的图标库,还有很多。 也许,我们需要的,这里都有。 有一点比较遗憾的是,不能直接下载图标库࿰

vue+element

因为element-ui内置的小图标非常有限,所以有时候,我们需要自定义或引入第三方图标库。

先介绍下阿里巴巴矢量图标库iconfont:

这个截图只显示了第一行的图标库,还有很多。

也许,我们需要的,这里都有。

有一点比较遗憾的是,不能直接下载图标库,只能一个个的添加入库(放入购物车,不花钱),加入项目(或新建项目并将入库的小图标加入项目),然后配置下载。

配置的主要是项目名称和图标前缀。

 

看一下上图所示的项目界面,其中font class和symbol显示的就是图标的英文名,unicode显示的就是:

(我们使用的是font class)

图中,更多操作里面有编辑项目:

其中项目名称和前缀配置一下,保存,然后下载至本地。解压后可以将所有文件复制粘贴到项目的/src/assets/myicon下,这个自己创建一个就好了,到时候引用css文件时知道自己把文件放哪了,会引用就可以。

比如,我的目录结构:

我在登陆的vue中引用图标css文件:

我在账号、密码的input处使用了:

但是,显示的不是小人和锁头,而是:

其他图标则显示为小方框。

那么,现在开始解决这个问题。经过在网上苦苦寻觅,却不能得到满意的答案后,我发现了:

在下载的图标库中有和demo_index.html

用浏览器打开demo_index.html图标是可以正常显示的,也就是说我们这里有一个正确配置和使用图标库的例子了。

而且其中还介绍了三种方式如何引入和使用图标库,其中font-class引用步骤如下:

下面,介绍下与demo_index.html这两个文件。(demo_index.html中使用font-class方式引用图标库,但使用方法和上图所述并不完全相同。)

(提示:代码粘出来了,但没必要全看,看自己的就好了,知道图标是怎么配置,怎么使用的就可以了)

(与demo_index.html样式有关,但是与其中图标的使用没什么关系)代码:

/* Logo 字体 */
@font-face {font-family: iconfont logo;src: url(	.eot?t=15458071884	);src: url(	.eot?t=15458071884#iefix	) format(	embedded-opentype	),url(	.woff?t=15458071884	) format(	woff	),url(	.ttf?t=15458071884	) format(	truetype	),url(	.svg?t=15458071884#iconfont	) format(	svg	);
}.logo {font-family: iconfont logo;font-size: 160px;font-style: normal;-webkit-font-smoothing: antialiased;-moz-osx-font-smoothing: grayscale;
}...

demo_index.html代码:

<!DOCTYPE html>
<html>
<head><meta charset=utf-8/><title>IconFont Demo</title><link rel=shortcut icon href=.ico type=image/x-icon/><link rel=stylesheet href=..2/><link rel=stylesheet href=><link rel=stylesheet href=><script src=iconfont.js></script><!-- jQuery --><script src=.js></script><!-- 代码高亮 --><script src=.js></script>
</head>
<body><div class=main><h1 class=logo><a href=/ title=iconfont 首页 target=_blank>&#xe86b;</a></h1><div class=nav-tabs><ul id=tabs class=dib-box><li class=dib active><span>Unicode</span></li><li class=dib><span>Font class</span></li><li class=dib><span>Symbol</span></li></ul><a href==myprojects&projectId=1155556 target=_blank class=nav-more>查看项目</a></div><div class=tab-container><div class=content unicode style=display: block;><ul class=icon_lists dib-box><li class=dib><span class=icon iconfont>&#xe6e;</span><div class=name>密码</div><div class=code-name>&amp;#xe6e;</div></li><li class=dib><span class=icon iconfont>&#xe64;</span><div class=name>账号</div><div class=code-name>&amp;#xe64;</div></li>...</ul><div class=article markdown><h2 id=unicode->Unicode 引用</h2><hr><p>Unicode 是字体在网页端最原始的应用方式,特点是:</p><ul><li>兼容性最好,支持 IE6,及所有现代浏览器。</li><li>支持按字体的方式去动态调整图标大小,颜等等。</li><li>但是因为是字体,所以不支持多。只能使用平台里单的图标,就算项目里有多图标也会自动去。</li></ul><blockquote><p>注意:新版 iconfont 支持多图标,这些多图标在 Unicode 模式下将不能使用,如果有需求建议使用symbol 的引用方式</p></blockquote><p>Unicode 使用步骤如下:</p><h id=-font-face>第一步:拷贝项目下面生成的 <code>@font-face</code></h>
<pre><code class=language-css
>@font-face {font-family: 	iconfont	;src: url(		);src: url(	?#iefix	) format(	embedded-opentype	),url(	iconfont.woff2	) format(	woff2	),url(	iconfont.woff	) format(	woff	),url(		) format(	truetype	),url(	iconfont.svg#iconfont	) format(	svg	);
}
</code></pre><h id=-iconfont->第二步:定义使用 iconfont 的样式</h>
<pre><code class=language-css
>.iconfont {font-family: iconfont !important;font-size: 16px;font-style: normal;-webkit-font-smoothing: antialiased;-moz-osx-font-smoothing: grayscale;
}
</code></pre><h id=->第三步:挑选相应图标并获取字体编码,应用于页面</h>
<pre>
<code class=language-html
>&lt;span class=iconfont&gt;&amp;#x;&lt;/span&gt;
</code></pre><blockquote><p>iconfont 是你项目下的 font-family。可以通过编辑项目查看,默认是 iconfont。</p></blockquote></div></div><div class=content font-class><ul class=icon_lists dib-box><li class=dib><span class=icon iconfont el-icon-qianniu-password></span><div class=name>密码</div><div class=code-name>.el-icon-qianniu-password</div></li><li class=dib><span class=icon iconfont el-icon-qianniu-account></span><div class=name>账号</div><div class=code-name>.el-icon-qianniu-account</div></li>...</ul><div class=article markdown><h2 id=font-class->font-class 引用</h2><hr><p>font-class 是 Unicode 使用方式的一种变种,主要是解决 Unicode 书写不直观,语意不明确的问题。</p><p>与 Unicode 使用方式相比,具有如下特点:</p><ul><li>兼容性良好,支持 IE8,及所有现代浏览器。</li><li>相比于 Unicode 语意明确,书写更直观。可以很容易分辨这个 icon 是什么。</li><li>因为使用 class 来定义图标,所以当要替换图标时,只需要修改 class 里面的 Unicode 引用。</li><li>不过因为本质上还是使用的字体,所以多图标还是不支持的。</li></ul><p>使用步骤如下:</p><h id=-fontclass->第一步:引入项目下面生成的 fontclass 代码:</h>
<pre><code class=language-html>&lt;link rel=stylesheet href=./&gt;
</code></pre><h id=->第二步:挑选相应图标并获取类名,应用于页面:</h>
<pre><code class=language-html>&lt;span class=iconfont el-icon-qianniu-xxx&gt;&lt;/span&gt;
</code></pre><blockquote><p>iconfont 是你项目下的 font-family。可以通过编辑项目查看,默认是 iconfont。</p></blockquote></div></div><div class=content symbol><ul class=icon_lists dib-box><li class=dib><svg class=icon svg-icon aria-hidden=true><use xlink:href=#el-icon-qianniu-password></use></svg><div class=name>密码</div><div class=code-name>#el-icon-qianniu-password</div></li><li class=dib><svg class=icon svg-icon aria-hidden=true><use xlink:href=#el-icon-qianniu-account></use></svg><div class=name>账号</div><div class=code-name>#el-icon-qianniu-account</div></li>...</ul><div class=article markdown><h2 id=symbol->Symbol 引用</h2><hr><p>这是一种全新的使用方式,应该说这才是未来的主流,也是平台目前推荐的用法。相关介绍可以参考这篇<a href=>文章</a>这种用法其实是做了一个 SVG 的集合,与另外两种相比具有如下特点:</p><ul><li>支持多图标了,不再受单限制。</li><li>通过一些技巧,支持像字体那样,通过 <code>font-size</code>, <code>color</code> 来调整样式。</li><li>兼容性较差,支持 IE9,及现代浏览器。</li><li>浏览器渲染 SVG 的性能一般,还不如 png。</li></ul><p>使用步骤如下:</p><h id=-symbol->第一步:引入项目下面生成的 symbol 代码:</h>
<pre><code class=language-html>&lt;script src=./iconfont.js&gt;&lt;/script&gt;
</code></pre><h id=-css->第二步:加入通用 CSS 代码(引入一次就行):</h>
<pre><code class=language-html>&lt;style&gt;
.icon {width: 1em;height: 1em;vertical-align: -0.15em;fill: currentColor;overflow: hidden;
}
&lt;/style&gt;
</code></pre><h id=->第三步:挑选相应图标并获取类名,应用于页面:</h>
<pre><code class=language-html>&lt;svg class=icon aria-hidden=true&gt;&lt;use xlink:href=#icon-xxx&gt;&lt;/use&gt;
&lt;/svg&gt;
</code></pre></div></div></div></div><script>$(document).ready(function () {$(	.tab-container .content:first	).show()$(	#tabs li	).click(function (e) {var tabContent = $(	.tab-container .content	)var index = $(this).index()if ($(this).hasClass(	active	)) {return} else {$(	#tabs li	).removeClass(	active	)$(this).addClass(	active	)tabContent.hide().eq(index).fadeIn()}})})</script>
</body>
</html>

vue项目的index.html:

<!DOCTYPE html>
<html><head><meta charset=utf-8><meta name=viewport content=width=device-width,initial-scale=1.0><title>xx系统</title><link rel=stylesheet href=./src/assets/myicon/><script src=./src/assets/myicon/iconfont.js></script></head><body><div id=app></div><!-- built files will be auto injected --></body>
</html>

不过在index.html中引用好像没什么用。

需要在main.js中引用(和iconfont.js,在demo_index.html中引入的不止这两个文件,但是其他的都与图标无关,之前网上的文章都是引入即可,但是我这样做后就显示不正常。):

//引入阿里巴巴图标库
import 	./assets/myicon/	
import 	./assets/myicon/iconfont.js	

而且,虽然仍然可以使用prefix-icon但是,不能只是写el-icon-qianniu-account ,前面要加上icon iconfont,这也是demo_index.html中的写法,登录界面,相关代码如下:

<el-form-item prop=username style=text-align: left>用户名:<el-input prefix-icon=icon iconfont el-icon-qianniu-account type=text v-model=loginForm.usernameauto-complete=off placeholder=账号></el-input></el-form-item><el-form-item prop=password style=text-align: left>密码:<el-input prefix-icon=icon iconfont el-icon-qianniu-password type=password v-model=loginForm.passwordauto-complete=off placeholder=密码></el-input></el-form-item>

现在成功了:

 

总结:

开始我一直在网上搜索“如何使用阿里巴巴图标库”、“阿里巴巴图标库 显示异常 小方框”等,到了一些文章,但是都不能解决我的问题,甚至想过要前端工作流程、工作机制、图标使用的原理啥的,无果,所以最终放弃继续在网上,寻思想想别的方法,就在这时,我注意到了和demo_index.html,虽然,我早就知道这两个文件的存在,以及它们是例子,但是却一直忽视了它们,直到我想别的方法时,才想要看看这两个文件里面有什么,html文件打开是什么样的。

这两个文件算是一手资料了,网上的文章,对于我们而言,是二手资料,有的时候不能很好的解决我们的问题(虽然很多时候,这些二手资料要比一手资料好用),所以我们就要想想怎么到并利用一手资料。

 

 

 

 

 

#感谢您对电脑配置推荐网 - 最新i3 i5 i7组装电脑配置单推荐报价格的认可,转载请说明来源于"电脑配置推荐网 - 最新i3 i5 i7组装电脑配置单推荐报价格

本文地址:http://www.dnpztj.cn/shuma/707482.html

相关标签:无
上传时间: 2023-11-21 21:17:25

上一篇:keep

下一篇:2020

留言与评论(共有 12 条评论)
本站网友 嘉兴租车
19分钟前 发表
url( .eot?t=15458071884 );src
本站网友 济南商铺租赁
23分钟前 发表
(demo_index.html中使用font-class方式引用图标库,但使用方法和上图所述并不完全相同
本站网友 田中芳树
16分钟前 发表
</li><li>兼容性较差,支持 IE9,及现代浏览器
本站网友 青蒿的功效与作用
18分钟前 发表
url( .eot?t=15458071884 );src
本站网友 狗肉和什么相克
26分钟前 发表
-0.15em;fill
本站网友 十五
25分钟前 发表
图标使用的原理啥的,无果,所以最终放弃继续在网上,寻思想想别的方法,就在这时,我注意到了和demo_index.html,虽然,我早就知道这两个文件的存在,以及它们是例子,但是却一直忽视了它们,直到我想别的方法时,才想要看看这两个文件里面有什么,html文件打开是什么样的
本站网友 苏泊尔炒锅哪种好
7分钟前 发表
</li><li>兼容性较差,支持 IE9,及现代浏览器
本站网友 可再生能源十二五规划
13分钟前 发表
grayscale; }... demo_index.html代码: <!DOCTYPE html> <html> <head><meta charset=utf-8/><title>IconFont Demo</title><link rel=shortcut icon href=.ico type=image/x-icon/><link rel=stylesheet href=..2/><link rel=stylesheet href=><link rel=stylesheet href=><script src=iconfont.js></script><!-- jQuery --><script src=.js></script><!-- 代码高亮 --><script src=.js></script> </head> <body><div class=main><h1 class=logo><a href=/ title=iconfont 首页 target=_blank>&#xe86b;</a></h1><div class=nav-tabs><ul id=tabs class=dib-box><li class=dib active><span>Unicode</span></li><li class=dib><span>Font class</span></li><li class=dib><span>Symbol</span></li></ul><a href==myprojects&projectId=1155556 target=_blank class=nav-more>查看项目</a></div><div class=tab-container><div class=content unicode style=display
本站网友 简约时尚电视背景墙
22分钟前 发表
只能使用平台里单的图标,就算项目里有多图标也会自动去
本站网友 今天的黄金价格是多少
6分钟前 发表
left>用户名:<el-input prefix-icon=icon iconfont el-icon-qianniu-account type=text v-model=loginForm.usernameauto-complete=off placeholder=账号></el-input></el-form-item><el-form-item prop=password style=text-align
本站网友 ivb
7分钟前 发表