寫(xiě)一個(gè)Vue loading 插件
作者:imgss
什么是vue插件?
- 從功能上說(shuō),插件是為Vue添加全局功能的一種機(jī)制,比如給Vue添加一個(gè)全局組件,全局指令等;
- 從代碼結(jié)構(gòu)上說(shuō),插件就是一個(gè)必須擁有install方法的對(duì)象,這個(gè)方法的接收的第一個(gè)參數(shù)是Vue構(gòu)造函數(shù),還可以接收一個(gè)可選的參數(shù),用于配置插件:
var myplugin = { install:function(Vue, options){ ... } }
從意義上來(lái)說(shuō),正如jQuery的$.fn
使jQuery有了一個(gè)龐大的生態(tài)一樣,Vue的插件機(jī)制使Vue形成了一個(gè)生態(tài)系統(tǒng),你可以開(kāi)發(fā)一個(gè)插件給別人復(fù)用。
使用插件
使用一個(gè)插件,只要像下面這樣:
Vue.use(myPlugin)
寫(xiě)一個(gè)loading插件
光說(shuō)不練假把式,接下來(lái)寫(xiě)一個(gè)loading插件練練手,這個(gè)插件被封裝成一個(gè)全局組件,實(shí)現(xiàn)下面的效果:
1 定義接口
我們希望應(yīng)用這個(gè)插件的方式如下:
<loading text='imgss' duration='3'></loading>
其中,text用于定義loading動(dòng)畫(huà)顯示的文字,duration定義動(dòng)畫(huà)時(shí)間
2 實(shí)現(xiàn)靜態(tài)組件
新建一個(gè)loading.js文件:
let myPlugin = { install: function (Vue, options) { Vue.component('loading', { props: { text:{ type:String }, duration:{ type:String, default:'1s'//默認(rèn)1s } }, data: function() { return {}; }, template: ` <div class='wrapper'> <div class='loading'> <span style='width:20px' v-for='char in text'>{{char}}</span> </div> </div> ` });
這里模板的作用在于,將輸入的字符串轉(zhuǎn)換成組成字符串的字符構(gòu)成的span元素;
接下來(lái),新建一個(gè)html文件:
<html> <head> <meta charset='utf-8'> <title>插件</title> </head> <body> <div id="app"> <loading text='imgss'></loading> <loading text='我是一個(gè)粉刷匠' duration='2s'></loading> </div> <script src="http://cdn.bootcss.com/vue/2.4.2/vue.js"></script> <script src="./loading.js"></script> <script> Vue.use(myPlugin); var app = new Vue({ el: '#app', data: { } }); </script> </body> </html>
這時(shí)基本上可以看到一個(gè)靜態(tài)效果。
3 加動(dòng)畫(huà)
給每個(gè)元素加上一個(gè)控制上下的animation
@keyframes move { 0% { margin-top: -10px; border-bottom: 1px solid; } 50% { margin-top: 10px; border-bottom: none; } 100% { margin-top: -10px; } }
除此之外,還有一下其他的公有樣式代碼,利用mounted
生命周期函數(shù),動(dòng)態(tài)生成一個(gè)style標(biāo)簽,將css代碼插到文檔中:
mounted: function () { var cssFlag = false; return function () { if (cssFlag) { return; } var head = document.querySelector('head'); var style = document.createElement('style'); style.type = 'text/css'; style.innerText = ` .wrapper{ display: flex; justify-content: center; } .loading { display: flex; text-align: center; padding-top: 30px; height: 50px; justify-content: space-between; } .loading span { margin-top: 0; animation: ease infinite move; display: block; } @keyframes move { 0% { margin-top: -10px; border-bottom: 1px solid; } 50% { margin-top: 10px; border-bottom: none; } 100% { margin-top: -10px; } }`; head.appendChild(style); cssFlag = true; }; }(),
然后通過(guò)控制span的animation-delay來(lái)模擬曲線:
<span :style='{ width: "20px", animationDuration: duration.indexOf("s") === -1 ? duration + "s" : duration , animationDelay: parseInt(duration)/text.length*index +"s" }' v-for='char,index in text'> {{char}} </span>
到這里,插件基本完成,看一下效果:
demo
以上就是寫(xiě)一個(gè)Vue loading 插件的詳細(xì)內(nèi)容,更多關(guān)于Vue 插件的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- vue開(kāi)發(fā)chrome插件,實(shí)現(xiàn)獲取界面數(shù)據(jù)和保存到數(shù)據(jù)庫(kù)功能
- vue自定義插件封裝,實(shí)現(xiàn)簡(jiǎn)易的elementUi的Message和MessageBox的示例
- vue打包通過(guò)image-webpack-loader插件對(duì)圖片壓縮優(yōu)化操作
- vue使用video插件vue-video-player詳解
- vue使用video插件vue-video-player的示例
- VSCode Vue開(kāi)發(fā)推薦插件和VSCode快捷鍵(小結(jié))
- 最全vue的vue-amap使用高德地圖插件畫(huà)多邊形范圍的示例代碼
- vscode 插件開(kāi)發(fā) + vue的操作方法
- 詳解vscode中vue代碼顏色插件
- 解決vue中使用swiper插件問(wèn)題及swiper在vue中的用法
- IntelliJ IDEA 安裝vue開(kāi)發(fā)插件的方法
- 推薦VSCode 上特別好用的 Vue 插件之vetur
- vue2.0實(shí)現(xiàn)倒計(jì)時(shí)的插件(時(shí)間戳 刷新 跳轉(zhuǎn) 都不影響)
- Vue 實(shí)現(xiàn)一個(gè)簡(jiǎn)單的鼠標(biāo)拖拽滾動(dòng)效果插件
相關(guān)文章
Vue.js第二天學(xué)習(xí)筆記(vue-router)
這篇文章主要為大家詳細(xì)介紹了Vue.js第二天的學(xué)習(xí)筆記,關(guān)于vue-router的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12使用Vue.js實(shí)現(xiàn)數(shù)據(jù)的雙向綁定
在Vue.js中,雙向數(shù)據(jù)綁定是一項(xiàng)非常強(qiáng)大的功能,它能夠使數(shù)據(jù)和視圖之間保持同步,讓開(kāi)發(fā)者更加方便地操作數(shù)據(jù),在本文中,我們將介紹如何用Vue.js實(shí)現(xiàn)數(shù)據(jù)的雙向綁定,需要的朋友可以參考下2023-04-04vue3循環(huán)設(shè)置ref并獲取的解決方案
我們?cè)谄綍r(shí)做業(yè)務(wù)的時(shí)候,父子組件通信會(huì)經(jīng)常用到ref,這篇文章主要給大家介紹了關(guān)于vue3循環(huán)設(shè)置ref并獲取的解決方案,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-02-02Vue中動(dòng)態(tài)class的多種寫(xiě)法
這篇文章主要介紹了Vue之動(dòng)態(tài)class的幾種寫(xiě)法,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-12-12vue中集成省市區(qū)街四級(jí)地址組件的實(shí)現(xiàn)過(guò)程
我們?cè)陂_(kāi)發(fā)中常會(huì)遇到選擇地址的需求,有時(shí)候只需要選擇省就可以,有時(shí)候則需要選擇到市、縣,以至于鄉(xiāng)鎮(zhèn),甚至哪個(gè)村都有可能,下面這篇文章主要給大家介紹了關(guān)于vue中集成省市區(qū)街四級(jí)地址組件的相關(guān)資料,需要的朋友可以參考下2022-12-12Vue或者React項(xiàng)目配置@路徑別名及智能提示方案
這篇文章主要介紹了Vue或者React項(xiàng)目配置@路徑別名及智能提示方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10