亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

寫(xiě)一個(gè)Vue loading 插件

瀏覽:6日期:2022-11-02 18:01:25

作者:imgss

出處:http://www.cnblogs.com/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)下面的效果:

寫(xiě)一個(gè)Vue loading 插件

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='http://www.aoyou183.cn/bcjs/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>

到這里,插件基本完成,看一下效果:

寫(xiě)一個(gè)Vue loading 插件

demo

代碼

codepen

以上就是寫(xiě)一個(gè)Vue loading 插件的詳細(xì)內(nèi)容,更多關(guān)于Vue 插件的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 国产一区二区三区在线电影 | 国产青青在线视频 | 免费观看亚洲 | 久久精品国产99久久3d动漫 | 五月天婷婷一区二区三区久久 | 日韩精品久久不卡中文字幕 | 可以看黄色的网址 | 久久精品国产精品亚洲综合 | 香蕉视频网站在线 | 三级小视频在线观看 | 亚洲欧美日韩中另类在线 | 婷婷六月久久综合丁香可观看 | 国产精品中文 | 中文字幕国产在线观看 | 金发美女大战黑人啪啪 | 1024亚洲天堂 | 日韩一卡2卡3卡四区别 | 永久免费在线观看视频 | 久久精品视频2 | 欧美日韩中文字幕久久伊人 | 色综合久久六月婷婷中文字幕 | 好大水好多好爽好硬好深视频 | 欧美三级在线观看视频 | 国产成人精品magnet | 视频精品一区二区三区 | 日韩伦理一区二区三区 | 欧美日韩久久毛片 | 色天天综合色天天害人害己 | 西西人体午夜视频 | 国产在线一区观看 | 日本一级特黄大一片免 | 国产五月色婷婷六月丁香视频 | 欧美色图一区 | 久久精品国产精品亚洲20 | 视频一区二区三区免费观看 | 亚洲综合色视频 | 国产精品国色综合久久 | 国产一二精品 | 成人影院欧美大片免费看 | 草草线在成人免费视频 | 欧美久久伊人 |