寫一個Vue loading 插件
作者:imgss
什么是vue插件?
- 從功能上說,插件是為Vue添加全局功能的一種機制,比如給Vue添加一個全局組件,全局指令等;
- 從代碼結(jié)構(gòu)上說,插件就是一個必須擁有install方法的對象,這個方法的接收的第一個參數(shù)是Vue構(gòu)造函數(shù),還可以接收一個可選的參數(shù),用于配置插件:
var myplugin = { install:function(Vue, options){ ... } }
從意義上來說,正如jQuery的$.fn
使jQuery有了一個龐大的生態(tài)一樣,Vue的插件機制使Vue形成了一個生態(tài)系統(tǒng),你可以開發(fā)一個插件給別人復(fù)用。
使用插件
使用一個插件,只要像下面這樣:
Vue.use(myPlugin)
寫一個loading插件
光說不練假把式,接下來寫一個loading插件練練手,這個插件被封裝成一個全局組件,實現(xiàn)下面的效果:
1 定義接口
我們希望應(yīng)用這個插件的方式如下:
<loading text='imgss' duration='3'></loading>
其中,text用于定義loading動畫顯示的文字,duration定義動畫時間
2 實現(xiàn)靜態(tài)組件
新建一個loading.js文件:
let myPlugin = { install: function (Vue, options) { Vue.component('loading', { props: { text:{ type:String }, duration:{ type:String, default:'1s'//默認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元素;
接下來,新建一個html文件:
<html> <head> <meta charset='utf-8'> <title>插件</title> </head> <body> <div id="app"> <loading text='imgss'></loading> <loading text='我是一個粉刷匠' 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>
這時基本上可以看到一個靜態(tài)效果。
3 加動畫
給每個元素加上一個控制上下的animation
@keyframes move { 0% { margin-top: -10px; border-bottom: 1px solid; } 50% { margin-top: 10px; border-bottom: none; } 100% { margin-top: -10px; } }
除此之外,還有一下其他的公有樣式代碼,利用mounted
生命周期函數(shù),動態(tài)生成一個style標簽,將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; }; }(),
然后通過控制span的animation-delay來模擬曲線:
<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
以上就是寫一個Vue loading 插件的詳細內(nèi)容,更多關(guān)于Vue 插件的資料請關(guān)注腳本之家其它相關(guān)文章!
- vue開發(fā)chrome插件,實現(xiàn)獲取界面數(shù)據(jù)和保存到數(shù)據(jù)庫功能
- vue自定義插件封裝,實現(xiàn)簡易的elementUi的Message和MessageBox的示例
- vue打包通過image-webpack-loader插件對圖片壓縮優(yōu)化操作
- vue使用video插件vue-video-player詳解
- vue使用video插件vue-video-player的示例
- VSCode Vue開發(fā)推薦插件和VSCode快捷鍵(小結(jié))
- 最全vue的vue-amap使用高德地圖插件畫多邊形范圍的示例代碼
- vscode 插件開發(fā) + vue的操作方法
- 詳解vscode中vue代碼顏色插件
- 解決vue中使用swiper插件問題及swiper在vue中的用法
- IntelliJ IDEA 安裝vue開發(fā)插件的方法
- 推薦VSCode 上特別好用的 Vue 插件之vetur
- vue2.0實現(xiàn)倒計時的插件(時間戳 刷新 跳轉(zhuǎn) 都不影響)
- Vue 實現(xiàn)一個簡單的鼠標拖拽滾動效果插件
相關(guān)文章
Vue.js第二天學(xué)習(xí)筆記(vue-router)
這篇文章主要為大家詳細介紹了Vue.js第二天的學(xué)習(xí)筆記,關(guān)于vue-router的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-12-12使用Vue.js實現(xiàn)數(shù)據(jù)的雙向綁定
在Vue.js中,雙向數(shù)據(jù)綁定是一項非常強大的功能,它能夠使數(shù)據(jù)和視圖之間保持同步,讓開發(fā)者更加方便地操作數(shù)據(jù),在本文中,我們將介紹如何用Vue.js實現(xiàn)數(shù)據(jù)的雙向綁定,需要的朋友可以參考下2023-04-04vue3循環(huán)設(shè)置ref并獲取的解決方案
我們在平時做業(yè)務(wù)的時候,父子組件通信會經(jīng)常用到ref,這篇文章主要給大家介紹了關(guān)于vue3循環(huán)設(shè)置ref并獲取的解決方案,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-02-02vue中集成省市區(qū)街四級地址組件的實現(xiàn)過程
我們在開發(fā)中常會遇到選擇地址的需求,有時候只需要選擇省就可以,有時候則需要選擇到市、縣,以至于鄉(xiāng)鎮(zhèn),甚至哪個村都有可能,下面這篇文章主要給大家介紹了關(guān)于vue中集成省市區(qū)街四級地址組件的相關(guān)資料,需要的朋友可以參考下2022-12-12