vue 动态绑定指令(vue动态绑定图标的完整步骤)
类别:编程学习 浏览量:2961
时间:2022-03-28 01:01:10 vue 动态绑定指令
vue动态绑定图标的完整步骤0 图标和图片的不同
图标时字符,图片时二进制流。即图片加载会比图标慢,且加载图标最好不要用img标签,我们可以把图标当成组件用import的方法引入进来,然后当成标签引入。
1 安装svg
1.使用管理员身份运行cmd窗口,切换到项目目录下执行。
npm add svg
2 从图标库下载图标
1.阿里图标库
https://www.iconfont.cn/
2.下载svg
3.在compone目录下建立一个icons,在icons下建立一个svg目录,专门用来放图标。
3 查看插件的使用方法
- vue所有的插件都在node_modules中
- 根据下载时的插件名来找到插件e-cli-plugin-svg的README
4 展示图标
1 定义动态组件MyIcon.vue
1.其中myicon是从父组件传过来的属性
2.computed是用来根据myicon.name(图标的名字)来动态生成图标地址的。原因是在export default{}外引入组件时,我们接收到的props属性是传递不到export default{}外面的,所以采用computed来协助生成icon组件。
3.:style是动态绑定样式,此处绑定了宽,高。并在props中设置了默认值,如果父组件不传递宽高信息的话,就是使用默认值。
4.:fill是绑定填充属性样式的,也在props中设置了默认值。
<template> <li> <component :is="icon" :style="{width : myicon.width , hight : myicon.hight}" :fill="myicon.fill" ></component> </li> </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动态绑定图标的文章就介绍到这了,更多相关vue动态绑定图标内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
您可能感兴趣
- vue考试链接重置(Vue实现答题功能)
- vue的路由模式有几种(Vue 路由返回恢复页面状态的操作方法)
- vue设置属性没响应(Vue.$set 失效的坑 问题发现及解决方案)
- vue3.0 黑暗风格(Vue3.0 手写放大镜效果)
- vue使用elementui框架(总结Vue Element UI使用中遇到的问题)
- elementui和vue详解(Vue+Element UI实现概要小弹窗的全过程)
- vue 怎么设置滚动条的长度(vue使用better-scroll实现横向滚动的方法实例)
- vue跨域代理怎么写(解决vue $http的get和post请求跨域问题)
- vue实现列表向上滚动更新(vue实现列表无缝滚动)
- vue如何在tab标签页循环加定时器(vue实现tab标签标签超出自动滚动)
- vue.js 怎么做插件(Vue.js实现音乐播放器)
- vue可以用vite打包吗(vite+vue3+element-plus项目搭建的方法步骤)
- 详解从vue的组件传值着手观察者模式(详解从vue的组件传值着手观察者模式)
- vue用手动上传图片(vue上传图片文件的多种实现方法)
- vue中的ref(Vue3.0中Ref与Reactive的区别示例详析)
- vue表单上传图片数据(vue-cropper插件实现图片截取上传组件封装)
- 今天要吃什么(今天要吃什么菜)
- 营养餐是什么(学校营养餐是什么)
- 谁说女子不如男 范冰冰演的武则天只是其一,另外两位你认识吗(谁说女子不如男)
- 杯酒人生---瓦伦丁酒杯和奥丁格啤酒(杯酒人生---瓦伦丁酒杯和奥丁格啤酒)
- 中秋节买啤酒,预算超过7元试试这8种啤酒,麦香浓郁都是真啤酒(预算超过7元试试这8种啤酒)
- CellPress旗下的6 期刊,国人友刊来了解一下吧(CellPress旗下的6期刊国人友刊来了解一下吧)
热门推荐
- MVC中使用jQuery加载分部视图(PartialView)
- border和background区别(css中background-origin属性的使用解析)
- css如何两列布局(浅谈CSS 多栏布局Multi-Columns Layout)
- escape()、encodeURI()、encodeURIComponent()区别
- react native web白屏(关于React Native 无法链接模拟器的问题)
- 阿里云几个服务器可以备案(阿里云服务器网站备案简单流程说明文档)
- wampserver安装后怎么使用(解决安装WampServer时提示缺少msvcr110.dll文件的问题)
- sqlserver2016使用教程(SQL Server 2016 Alwayson新增功能图文详解)
- sqlifnull如何使用(在 SQL 语句中处理 NULL 值的方法)
- :link,:visited,:focus,:hover,:active的用法
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9