网页上使用的图标分可为三种:文件图标、字体图标和 SVG 图标。对于文件图标,下面仅以 PNG 格式来说明。

PNG 图标
对于 PNG 图标的引用,有两种方式。一种是直接由 HTML 元素 img 的 src 属性给出。下面是一个简单的示例。
Icon: {
css: "#icon { width: 68px; height: 68px; }",
xml: "<img id='icon'/>",
fun: function (sys, items, opts) {
this.attr("src", this + ".png");
}
}
这里假定图标文件与组件所在文件在同级目录中,于是可以按如下的方式便捷地引用所需的图标。注意组件 Icon 巧妙地使 id 属性值与图片文件名关联,这样可以避免创建额外的属性。
Example: {
css: "#example > * { padding: 10px; background: #F9F9F9; }",
xml: "<div id='example' class='bs-example'>\
<Icon id='msg'/>\
<Icon id='home'/>\
<Icon id='contact'/>\
</div>"
}
另一种引用 PNG 图标的方式是给相应的对象添加 background-image 样式,并且由样式中给出图标所在路径。下面是一个简单的示例。
Icon: {
css: "#icon { width: 68px; height: 68px; }",
xml: "<div id='icon'/>",
fun: function (sys, items, opts) {
this.css("background-image", this + ".png");
}
}
这种形式与前面由 img 标签给出的图标有许多相似之处。不同的是,前者动态指定的是 img 标签的 src 值 ,而后者动态指定的则是 div 元素的 css 样式。该组件与前面给出的 Icon 组件的使用方式完全一致,这里就不重复了。
对于以上给出的组件 Icon,使用的是离散的图标文件。实际应用中,通常给出的是一个包含许多图标的 PNG 文件。这种情况下该如何构建图标组件呢?请看下面给出的一种较为实用的方案。
Icon: {
css: "#msg { background-position: 0 0; }\
#home { background-position: -48px 0; }\
#contact { background-position: -96px 0; }\
#icon { width: 68px; height: 68px; background-image: url(icons.png); }",
xml: "<div id='icon'/>",
fun: function (sys, items, opts) {
sys.icon.addClass("#" + this);
}
}
此组件在样式项 css 中直接给出了图标文件所在路径,以及各种图标在文件内的位置。并且图标实例 id 与相应图标类名对应。当然,组件的使用方式与前面给出的组件是一致的。
下面给出的是另一种组件设计方案,它把位置信息移到了函数项中。此方案是可行的,但组件的执行效率不如前者。该组件每次实例化都要生成位置信息一次,而对于前者,由于样式项在组件实例化时,仅生成一次,所以保证了组件的执行性能。
Icon: {
css: "#icon { width: 48px; height: 48px; background-image: url(icons.png); }",
xml: "<div id='icon'/>",
fun: function (sys, items, opts) {
var positions = {
"msg": "0 0",
"home": "-48px 0",
"contact": "-96px 0"
}
sys.icon.css("background-position", positions[this]);
}
}
字体图标
字体图标通过引入包含图标的字体文件,将图标像文字一样使用。它与 PNG 图标相比,最关键一点在于它的矢量性。字体图标的引用方式有两种:通过类名的引用方式以及直接引用 unicode 的方式。
通过类名引用
这种类型的图标内容定义在样式项中,HTML 元素通过类名进行关联。
Msg: {
css: "#msg { font-size: 48px; width: 68px; height: 68px; line-height: 48px; }\
#msg:before { content: '\\e608'; }",
xml: "<div id='msg'/>"
}
直接引用unicode
这种引用方式与前一种在本质上没什么不同,它只是将图标内容由样式项转移到视图项中而已。
Home: {
css: "#home { font-size: 48px; width: 68px; height: 68px; line-height: 48px; }",
xml: "<div id='home'><div/>"
}
下面给出的示例展示了两种不同的引用字体图标的方式。注意,此示例简化了样式项中与兼容性相关的内容,详情请查阅配套源码。
Example: {
css: "@font-face { font-family: 'iconfont'; url('iconfont.ttf') format('truetype');}\
#msg, #home { font-family: 'iconfont'; font-style:normal; }\
#example > * { display: inline-block; padding: 10px; background: #F9F9F9; }",
xml: "<div id='example'>\
<Msg id='msg'/>\
<Home id='home'/>\
</div>"
}
SVG 图标
最后来看看我们的重头戏,如何封装以及使用 SVG 图标。在 xmlplus 中,SVG 图标是推荐的图标使用形式,它允许直接嵌入代码,无需额外引用相关文件。
通过 xlink:href 引用
对于这种方式,首先你需要一个 svg 图标集,其包含的内容大概是下面这样子。
<svg>
<symbol id="icon" width='48px' height='48px' viewBox='0 0 24 24'>
<g><polygon points='9,16.2 4.8,12 3.4,13.4 9,19 21,7 19.6,5.6'/></g>\
</symbol>
<!-- 还可以有更多的symbol -->
</svg>
svg 图标集有两种存在方式,一个是以文件形式存在,这时 xlink:href 属性值需要明确指明文件的 url,下面是一个示例。
<svg> <use xlink:href='http://example.com/file.svg#icon'/>\ </svg>
另一种形式是,图标集直接存在于页内,这种方式叫做页内引用,它无需指明 url,只要指定相应 symbol 的 id 就好了。
<svg> <use xlink:href='#icon'/>\ </svg>
对svg 图标的直接封装
相对于通过 xlink:href 引用图标,使用 xmlplus 的组件化技术直接封装会是一种更好的方式。请看下面的一个 SVG 图标组件。
Icon: {
xml: "<svg width='48px' height='48px' viewBox='0 0 24 24'>\
<g><polygon points='9,16.2 4.8,12 3.4,13.4 9,19 21,7 19.6,5.6'/></g>\
</svg>",
fun: function (sys, items, opts) {
this.attr("fill", '' + this);
}
}
这是一个钩形图标,组件中仅包含视图项以及函数项成份。根据函数项的内容可以知道,图标颜色由组件实例的 id 属性值给出。下面来看看如何使用该图标。
Example: {
css: "#example > * { padding: 10px; background: #F9F9F9; }\
#example > *:hover { fill: #fff; background: #563d7c; }",
xml: "<div id='example'>\
<Icon id='red'/>\
<Icon id='green'/>\
<Icon id='blue'/>\
</div>",
fun: function (sys, items, opts) {
sys.example.on("click", "*", e => console.log(this + " clicked"));
}
}
此示例展示了三个不同颜色的图标,并且侦听了图标的点击事件,打开浏览器控制台,当点击不同图标时,可以看到相应的输出。
另外,有一种常见的 SVG 图标的封装方式,它把 SVG 文本经过 URL 编码后直接在 img 的 src 属性或者样式 background-image 中给出。就像下面这样子。
Icon: {
css: "#icon {width: 16px; height: 16px; background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20viewBox%3D...")},
xml: "<div id='icon'/>"
}
这种方式与上一种方式比起来,有两个缺点:其一,你看不出 SVG 的源文件。其二,你失去了对 SVG 图标的操作权。当然,这种方式也并非不能用。如果你不需要对图标进行后续的操作,使用这种方式也是可以接受的。另外,与之相似的一种图标使用方式是对图标 base64 编码后的内嵌引用。下面是一个简单的示范:
Icon: {
xml: "<img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAIcAAA..." />"
}
这种方式与上一种 SVG 图标的封装方式是类似的。不过相对于 SVG 图标组件的直接封装,你同样失去了对图标的操作权。
本系列文章基于 xmlplus 框架。如果你对 xmlplus 没有多少了解,可以访问 www.xmlplus.cn。这里有详尽的入门文档可供参考。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# xmlplus
# 图标
# ICON
# xmlplus组件设计系列之网格(DataGrid)(10)
# xmlplus组件设计系列之文本框(TextBox)(3)
# xmlplus组件设计系列之选项卡(Tabbar)(5)
# xmlplus组件设计系列之下拉刷新(PullRefresh)(6)
# xmlplus组件设计系列之路由(ViewStack)(7)
# xmlplus组件设计系列之分隔框(DividedBox)(8)
# xmlplus组件设计系列之树(Tree)(9)
# xmlplus组件设计系列之按钮(2)
# xmlplus组件设计系列之列表(4)
# 的是
# 是一个
# 有两种
# 来看看
# 相对于
# 这样子
# 它把
# 失去了
# 如果你
# 是一种
# 就像
# 出了
# 还可以
# 都要
# 展示了
# 不出
# 就不
# 之处
# 则是
# 两种
相关文章:
网站制作公司排行榜,抖音怎样做个人官方网站
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
香港网站服务器数量如何影响SEO优化效果?
python的本地网站制作,如何创建本地站点?
,制作一个手机app网站要多少钱?
建站主机解析:虚拟主机配置与服务器选择指南
ppt制作免费网站有哪些,ppt模板免费下载网站?
C#如何在一个XML文件中查找并替换文本内容
如何在IIS服务器上快速部署高效网站?
网站制作话术技巧,网站推广做的好怎么话术?
如何快速搭建支持数据库操作的智能建站平台?
网站企业制作流程,用什么语言做企业网站比较好?
建站之星会员如何解锁更多建站功能?
网站视频怎么制作,哪个网站可以免费收看好莱坞经典大片?
建站之星如何通过成品分离优化网站效率?
建站之星代理平台如何选择最佳方案?
建站之星logo尺寸如何设置最合适?
黑客入侵网站服务器的常见手法有哪些?
如何在IIS管理器中快速创建并配置网站?
建站主机功能解析:服务器选择与快速搭建指南
如何零基础开发自助建站系统?完整教程解析
如何在云服务器上快速搭建个人网站?
如何在七牛云存储上搭建网站并设置自定义域名?
建站主机核心功能解析:服务器选择与网站搭建流程指南
建站主机是否等同于虚拟主机?
建站之星ASP如何实现CMS高效搭建与安全管理?
制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?
中山网站制作网页,中山新生登记系统登记流程?
常州企业建站如何选择最佳模板?
商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?
网站制作免费,什么网站能看正片电影?
c# 在ASP.NET Core中管理和取消后台任务
建站之星各版本价格是多少?
广州营销型建站服务商推荐:技术优势与SEO优化解析
教育培训网站制作流程,请问edu教育网站的域名怎么申请?
SQL查询语句优化的实用方法总结
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
如何通过建站之星自助学习解决操作问题?
微信推文制作网站有哪些,怎么做微信推文,急?
网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?
存储型VPS适合搭建中小型网站吗?
如何在万网开始建站?分步指南解析
如何通过商城自助建站源码实现零基础高效建站?
香港服务器建站指南:免备案优势与SEO优化技巧全解析
长沙企业网站制作哪家好,长沙水业集团官方网站?
建站之星客服服务时间及联系方式如何?
宝华建站服务条款解析:五站合一功能与SEO优化设置指南
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
免费公司网站制作软件,如何申请免费主页空间做自己的网站?
南宁网站建设制作定制,南宁网站建设可以定制吗?
*请认真填写需求信息,我们会在24小时内与您取得联系。