国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

詳解關(guān)于Vue單元測(cè)試的幾個(gè)坑

瀏覽:8日期:2023-01-24 15:56:28

一、寫在前面

這篇文章的代碼使用karma,mocha,chai,sinon-chai配合Vue的實(shí)例屬性進(jìn)行單元測(cè)試

二、全局的組件的坑

由于我的g-icon是全局注冊(cè)的,所以使用g-input組件時(shí)的時(shí)候g-icon是直接用的,所以測(cè)試時(shí)有關(guān)icon的代碼永遠(yuǎn)是錯(cuò)的。

把g-icon局部注冊(cè)的組件

三、在測(cè)試中觸發(fā)點(diǎn)擊事件

模擬我在app.vue里使用g-input組件

<g-input v-model='message'></g-input>

使用new event 和 dispatch 模擬事件在組件上觸發(fā),雖然這個(gè)事件和我們實(shí)際的事件不一樣,但名字一樣就夠了,測(cè)試回調(diào)函數(shù)自帶的參數(shù)

it('支持事件', () => { ['change', 'input', 'focus', 'blur'].forEach(eventName => { vm = new Constructor({}).$mount(); const callback = sinon.fake(); vm.$on(eventName, callback); let event = new Event(eventName); Object.defineProperty(event, 'target', { value: { value: 'hi' }, enumerable: true }); let inputElement = vm.$el.querySelector('input'); inputElement.dispatchEvent(event); expect(callback).to.have.been.calledWith('hi'); }); });

測(cè)試這個(gè)組件事件觸發(fā)時(shí),回調(diào)的參數(shù),由于自定義事件沒有target,我們需要自己寫上去

value: { value: 'hi' }第一個(gè)value是defineProperty的

四、Vue的版本

坑來自于下面一段代碼

it('接受gutter', function(done) { Vue.component('g-row', Row); Vue.component('g-col', Col); const div = document.createElement('div'); document.body.appendChild(div); div.innerHTML = ` <g-row gutter='20'> <g-col></g-col> <g-col></g-col> </g-row>`; const vm = new Vue({ el: div }); setTimeout(() => { const row = vm.$el.querySelector('.row'); expect(getComputedStyle(row).marginRight).to.eq('-10px'); expect(getComputedStyle(row).marginLeft).to.eq('-10px'); const cols = vm.$el.querySelectorAll('.col'); expect(getComputedStyle(cols[0]).paddingRight).to.eq('10px'); expect(getComputedStyle(cols[1]).paddingLeft).to.eq('10px'); done(); vm.$el.remove(); vm.$destroy(); }, 0); });

我使用直接在el上寫入template代碼,所以我默認(rèn)的import Vue from 'vue'(runtimeonly版本)無法編譯這個(gè)代碼,import Vue from '../node_modules/vue/dist/vue.esm.js'使用上面引入即可

在沒有template選項(xiàng)是,el不替換

五、異步測(cè)試

還是這個(gè)代碼,先看以下測(cè)試兩個(gè)組件關(guān)系

it('接受gutter', function(done) { Vue.component('g-row', Row); Vue.component('g-col', Col); const div = document.createElement('div'); document.body.appendChild(div); div.innerHTML = ` <g-row gutter='20'> <g-col></g-col> <g-col></g-col> </g-row>`; const vm = new Vue({ el: div }); setTimeout(() => { const row = vm.$el.querySelector('.row'); expect(getComputedStyle(row).marginRight).to.eq('-10px'); expect(getComputedStyle(row).marginLeft).to.eq('-10px'); const cols = vm.$el.querySelectorAll('.col'); expect(getComputedStyle(cols[0]).paddingRight).to.eq('10px'); expect(getComputedStyle(cols[1]).paddingLeft).to.eq('10px'); done(); vm.$el.remove(); vm.$destroy(); }, 0); });

先說為什么需要seTimeout

從created和mounted鉤子說起,createElement和appendChild在js代碼是同步的,兩個(gè)鉤子分別在這兩段代碼后執(zhí)行,鉤子異步執(zhí)行的。

由于我們?cè)趃-row組件中有mounted鉤子,所以我們必須得進(jìn)行異步檢測(cè),否則我們?cè)趎ew Vue之后立馬進(jìn)行測(cè)試,鉤子還沒執(zhí)行完。

mocha異步測(cè)試

mocha默認(rèn)不執(zhí)行異步,加入done參數(shù),調(diào)用done()就可以

六、垃圾回收

每一個(gè)測(cè)試完成之后,都要寫下面兩條代碼

vm.$el.remove(); vm.$destroy();

有兩個(gè)作用:

銷毀在頁面中的數(shù)據(jù) 銷毀在內(nèi)存的數(shù)據(jù)

雖然js是單線程,但是還有一個(gè)dom線程

var div = document. getElementById(’xxx’)div.onclick = function() { ///code}setTimeout(function(){ div. remove()}, 3000)

現(xiàn)在我們討論,什么時(shí)候div上的函數(shù)被回收

函數(shù)被全局變量div上的onlick引用了

div.remove()只是在頁面刪掉了,沒有被內(nèi)存刪掉

var div = document. getElementById(’xxx’)div.onclick = function() { ///code}setTimeout(function(){ div = mull}, 3000)

這個(gè)函數(shù)并沒有被刪除,函數(shù)是寫在dom上的,div變量只是引用了dom對(duì)象

var div = document. getElementById(’xxx’)div.onclick = function() { ///code}setTimeout(function(){ var div2 = document. getElementById(’xxx’)}, 3000)

div= null和div.remove同時(shí)做就可以了,分別從內(nèi)存和dom上刪除了

ie有bug,即使這樣都刪不了,div.onlick = null 可以

到此這篇關(guān)于關(guān)于Vue單元測(cè)試的幾個(gè)坑的文章就介紹到這了,更多相關(guān) Vue單元測(cè)試 內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 男人的天堂官网 | 成人a毛片免费全部播放 | 国产又粗又黄又湿又大 | 国产午夜亚洲精品一区网站 | 国产一级特黄特色aa毛片 | 久草久草在线视频 | 欧美另类专区 | 久久久9视频在线观看 | 中国女人毛茸茸免费视频 | 精品视频一区二区 | 成年人网站免费看 | 亚洲七七久久精品中文国产 | 亚洲精品一区二区观看 | 亚洲精品一区二区三区四区手机版 | 亚洲九九 | 欧美大片a一级毛片视频 | chinese性老妇中国 | 香港经典a毛片免费观看看 香港经典a毛片免费观看爽爽影院 | 国内久久精品 | 伊人久久综合热青草 | 亚洲热视频 | 国产成 人 综合 亚洲绿色 | 国产午夜精品理论片久久影视 | 性做爰片免费视频毛片中文i | 点击进入不卡毛片免费观看 | 成人免费观看一区二区 | 最新在线精品国自拍视频 | 亚洲最新 | 亚洲影院手机版777点击进入影院 | 亚洲欧美综合久久 | 国产一级aaaaa毛片欧美 | 成人久久网 | 模特精品一区二区三区 | 国产一级小视频 | 高清国产一级精品毛片基地 | 在线免费观看精品 | 亚洲精品国产美女在线观看 | 国产高清美女一级毛片久久 | 国产精品中文 | 日韩亚洲天堂 | 久久99在线 |