温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何在vue中动态绑定图标

发布时间:2021-05-24 15:45:33 来源:亿速云 阅读:346 作者:Leah 栏目:开发技术

本篇文章为大家展示了如何在vue中动态绑定图标,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

1 安装svg

1.使用管理员身份运行cmd窗口,切换到项目目录下执行。

npm add svg

2 从图标库下载图标

1.阿里图标库

https://www.iconfont.cn/

2.下载svg

如何在vue中动态绑定图标

3.在compone目录下建立一个icons,在icons下建立一个svg目录,专门用来放图标。

如何在vue中动态绑定图标

3 查看插件的使用方法

  • vue所有的插件都在node_modules中

  • 根据下载时的插件名来找到插件e-cli-plugin-svg的README

如何在vue中动态绑定图标

4 展示图标

1 定义动态组件MyIcon.vue

1.其中myicon是从父组件传过来的属性

2.computed是用来根据myicon.name(图标的名字)来动态生成图标地址的。原因是在export default{}外引入组件时,我们接收到的props属性是传递不到export default{}外面的,所以采用computed来协助生成icon组件。

3.:style是动态绑定样式,此处绑定了宽,高。并在props中设置了默认值,如果父组件不传递宽高信息的话,就是使用默认值。

4.:fill是绑定填充属性样式的,也在props中设置了默认值。

<template>
	<div>
		<component
			:is="icon"
			:
			:fill="myicon.fill"
		></component>
		
	</div>
</template>

<script>
	
	export default{
		props:{
			myicon:{
				name:{
					type:String
				},
				
				width:{
					type:String,
					default:'40px'
				},
				hight:{
					type:String,
					default:'40px'
				},
				fill:{
					type:String,
					default:'#000000'
				}
			}
			
			

		},
			
		computed:{
			icon(){
				return () => import('@/components/icons/svg/'+ this.myicon.name +'.svg?inline')
			}
			
		}			
	}
</script>

<style>	

</style>

2 在main,js中全局引入并定义组件MyIcon.vue

import mysvg from '@/components/MyIcon.vue'
Vue.component('my-icon',mysvg)

3 调用my-icon作为父组件

1.把要传递的属性定义在myicon:{}中,其中name是必填项,它是图标的名字,不带后缀。

<template>
	
					<my-icon
						:name = "scope.row.icon"
						:width = "50px"
						:hight = "50px"
						:fill =  "#ff00ff">
					</my-icon>
					
</template>

<script>
	
	
	
	export default {

		data() {				
			return {		
				
				myicon:{					
					name: "position",
					width: "60px",
					hight: "60px",
					fill : "#ff00ff"					
				},

				

			}
		},
	}
</script>

<style scoped lang="less">	
</style>

上述内容就是如何在vue中动态绑定图标,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

vue
AI