Css3的attr函数使用,加载unicode图标

开发 前端
我们注意到我们在i标签上将icon-shanchu替换成了自己自定义的一个class,但同时也多了一个自定义属性unicode="",这是一个很有用的属性,通常我们需要动态的更换图标时,我们就可以把这个unicode写在标签上,那怎么才能显示呢?

阿里矢量图标​在项目中都用使用,通常一般我们引入css​使用iconfont​,或者我们使用svg​加载图标,亦或我们可以使用Unicode​,除了第一种与第二种,今天分享第三种方式unicode加载图标,希望看完在项目中能有所思考和帮助。

css加载图标

这是我们项目中最常用的一种方式。

我在自己的iconfont仓库中添加了几个图标。

图片

打开前阵子我开源的一个移动端项目topfreeApplication

我们在common.less中引入阿里矢量图标的这个css。


/*src/assets/css/common.less*/
@import url('./normalize.less');
@import url('//at.alicdn.com/t/c/font_3470263_sw1krly77xh.css');

我在src/pages/home/component/Search.vue引入一个图标。

图片

所以加入了一行代码,就将删除图标就加入我们的页面中了。

图片

svg图标

在这之前,我们都是用class​方式加载,现在我们看下svg方式加载图标。

在src/pages/home/component/Search.vue​组件中也看到我使用一个svg-icon的二次组件加载图标的。

我把svg-icon注册成一个全局组件。


<!--src/components/svg-icon/view/Index.vue-->
<script lang="tsx">
// 必须引入iconfont.js
import '@/assets/font/iconfont';
import { defineComponent, PropType, useAttrs } from 'vue';

export default defineComponent({
name: 'SvgIcon',
props: {
name: {
type: String as PropType<string>,
default: '',
required: true,
},
iconClass: {
type: String as PropType<string>,
default: '',
required: false,
},
},
render() {
const { name, iconClass } = this;
return (
<svg class={`icon ${iconClass}`} aria-hidden="true" {...useAttrs()}>
<use xlinkHref={`#icon-${name}`}></use>
</svg>
);
},
});
</script>
<style lang="less" scoped>
.icon {
fill: currentColor;
overflow: hidden;
}
</style>

src/components/index.ts


import SvgIcon from './svg-icon';
import DataEmpty from './data-empty';

const customComponents = {
SvgIcon,
CDataEmpty: DataEmpty,
};

export const installComponent = (app) => {
// 自定义注册全局组件
Object.keys(customComponents).forEach((key: string) => {
app.component(key, customComponents[key]);
});
};

注意我们必须引入iconfont.js具体可以参考使用web文档

uniCode 加载图标

我们注意到我们css加载图标实际上图标的一个伪类元素加载的一个unicode。

图片

加载图标实际上是引用了一个uncode​,所以我们可以借鸡生蛋。

<template>
<div class="search-bar">
<div class="inner">
<svg-icon name="sousuo" width="20" height="20" class="search-icon" />
<input
type="text"
v-model="searchVal"
@input="handleVal"
class="input-search"
placeholder="Search..."
/>
<svg-icon
name="guanbi"
width="20"
height="20"
class="close-icon"
@click="handleClear"
v-if="searchVal"
/>
<!-- <i class="iconfont icon-shanchu"></i> -->
<i class="iconfont maic-del" unicode="&#xe718;"></i>
</div>
</div>
</template>

我们注意到我们在i​标签上将icon-shanchu​替换成了自己自定义的一个class​,但同时也多了一个自定义属性unicode="&#xe718;"​,这是一个很有用的属性,通常我们需要动态的更换图标时,我们就可以把这个unicode写在标签上,那怎么才能显示呢?

css​有一个超强的函数特性attr​,在css里面我们可以动态的取到unicode的值。

我们看下css​代码,注意unicode就是你标签上的那个属性。

.maic-del {
&::before {
content: attr(unicode);
}
}

注意到没有,利用attr​这个特性就可以成功的加载到unicode​了(不过注意,因为我这个是vue3项目,在vue2中,我们必须v-html渲染这整个标签,不然图标始终显示不出来)

图片

所以你会发现在css​中你用attr​这个属性就可以动态的加载标签上的unicode了。

css的Attr

在以上我们的图标用unicode​就可以加载图标,同时我们也知道利用css中的attr函数成功解决了图标加载问题。

我们看看attr这个属性可以在我们项目中怎么用,在哪些场景可以用?

我们尝试写一个计数器。

  <div id="app">
<button id="startBtn">开始计数</button>
<div class="content" data-content="10"></div>
</div>

对应的css。

  * {
padding: 0;
margin: 0;
}
:root {
--color: red;
--width: 200px;
--height: 200px;
}
#app {
width: var(--width);
height: var(--height);
margin: 0 auto;
border: 1px solid var(--color);
}
#app button {
margin: 5px 10px;
}
.content {
height: calc(var(--width) / 2);
border: 1px solid green;
text-align: center;
line-height: calc(var(--width) / 2);
font-size: 50px;
}
.content::before {
content: attr(data-content);
display: inline-block;
}

我们使用了css3​的函数var​,以及calc​,还有attr​,这些都是css3​的函数,注意var​中的变量必须在:root{}​中用--xxx申明成全局,即可使用

看下布局后的基本页面。

图片

我们再看下对应的​js。

// requestAnimationFrame 模拟setInterval
function customizeSetInterval(callback, interval) {
let timer = null;
let startTime = Date.now();
let loop = () => {
let endTime = Date.now();
if (endTime - startTime >= interval) {
startTime = endTime = Date.now();
callback(timer);
}
timer = window.requestAnimationFrame(loop);
};
loop();
return timer;
}
const startBtn = document.getElementById("startBtn");
const contentDom = document.querySelector(".content");
let initData = contentDom.dataset.content * 1;
startBtn.onclick = function () {
setCount();
};
// 计数操作
function setCount(interval = 1000) {
const timer = customizeSetInterval(() => {
if (initData >= 0) {
startBtn.innerText = "正在计数...";
contentDom.setAttribute("data-content", initData--);
}
if (initData === -1) {
startBtn.innerText = "重新计数";
}
}, interval);
if (initData === -1) {
initData = 10;
window.cancelAnimationFrame(timer);
}
}

我们通过操作.content的data-content,因此可以实现一个简单的倒计时效果。

因此我们就用css中attr​结合js​实现了一个计数器功能,关于cssattr​还有更多待挖掘的功能,在动态改变图标等,attr是一种不错的选择方案

总结

  • 加载阿里矢量图标除了使用class与svg​,我们也可以使用attr​加载使用unicode。
  • css3​函数var,calc,attr的使用。
  • 使用css的attr特性简单实现计数器的效果。
  • 本文示例code example​。

参考资料

[1]iconfont: https://www.iconfont.cn/

[2]topfreeApplication: https://github.com/maicFir/topfreeApplication

[3]web文档: https://www.iconfont.cn/help/detail?spm=a313x.7781069.1998910419.d8cf4382a&helptype=code

[4]code example: https://github.com/maicFir/lessonNote/tree/master/html/07-attr

责任编辑:武晓燕 来源: Web技术学苑
相关推荐

2024-04-28 08:31:47

CSS3Clamp()函数响应式设计工具

2013-01-30 15:59:29

adobeCSS3HTML5

2021-06-09 08:30:52

CSS33D旋转视图3D动画

2012-03-02 10:50:20

jQuery

2012-09-13 09:24:31

CSSJSjQ

2015-10-14 09:50:11

css3动画模拟

2021-01-05 08:10:00

Css前端3D旋转透视

2015-10-09 09:43:28

CSS CSS3

2012-05-27 18:28:46

jQuery Mobi

2021-09-08 22:28:13

前端Css3动画

2012-02-24 09:11:45

jQuery

2012-04-10 10:31:07

2011-11-25 13:18:40

HTML 5

2011-11-17 09:24:27

HTML 5

2024-05-31 00:00:01

2022-02-20 14:45:33

3D动画CSS3前端

2011-05-11 16:13:43

CSS3

2015-05-27 07:44:34

日历控件 jQueryCSS3

2011-12-16 11:11:36

HTML 5

2011-03-22 08:54:02

HTML 5CSS3JavaScript
点赞
收藏

51CTO技术栈公众号