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

您的位置:首頁技術文章
文章詳情頁

詳解關于Vue單元測試的幾個坑

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

一、寫在前面

這篇文章的代碼使用karma,mocha,chai,sinon-chai配合Vue的實例屬性進行單元測試

二、全局的組件的坑

由于我的g-icon是全局注冊的,所以使用g-input組件時的時候g-icon是直接用的,所以測試時有關icon的代碼永遠是錯的。

把g-icon局部注冊的組件

三、在測試中觸發點擊事件

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

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

使用new event 和 dispatch 模擬事件在組件上觸發,雖然這個事件和我們實際的事件不一樣,但名字一樣就夠了,測試回調函數自帶的參數

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'); }); });

測試這個組件事件觸發時,回調的參數,由于自定義事件沒有target,我們需要自己寫上去

value: { value: 'hi' }第一個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代碼,所以我默認的import Vue from 'vue'(runtimeonly版本)無法編譯這個代碼,import Vue from '../node_modules/vue/dist/vue.esm.js'使用上面引入即可

在沒有template選項是,el不替換

五、異步測試

還是這個代碼,先看以下測試兩個組件關系

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-row組件中有mounted鉤子,所以我們必須得進行異步檢測,否則我們在new Vue之后立馬進行測試,鉤子還沒執行完。

mocha異步測試

mocha默認不執行異步,加入done參數,調用done()就可以

六、垃圾回收

每一個測試完成之后,都要寫下面兩條代碼

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

有兩個作用:

銷毀在頁面中的數據 銷毀在內存的數據

雖然js是單線程,但是還有一個dom線程

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

現在我們討論,什么時候div上的函數被回收

函數被全局變量div上的onlick引用了

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

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

這個函數并沒有被刪除,函數是寫在dom上的,div變量只是引用了dom對象

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

div= null和div.remove同時做就可以了,分別從內存和dom上刪除了

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

到此這篇關于關于Vue單元測試的幾個坑的文章就介紹到這了,更多相關 Vue單元測試 內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Vue
相關文章:
主站蜘蛛池模板: 日韩 亚洲 制服 欧美 综合 | 毛片视频免费 | 国产精品久久永久免费 | 99久久精品视香蕉蕉er热资源 | 国产精品久久成人影院 | 中文字幕电影在线 | 久久精品一 | 国产精品久久久久久久久久日本 | 亚洲第一区视频在线观看 | 秀人网艾小青国产精品视频 | 日本一级毛片不卡免费 | 最新久久精品 | 特黄特黄一级高清免费大片 | 国产精品果冻麻豆精东天美 | 日韩a毛片 | 成人黄色在线观看视频 | 福利网站污 | 黄页网址免费 | 天天干成人网 | 国产69页 | 小泽玛利亚在线精品一区二区 | 国产对白91色拍高清精品 | 久久精品嫩草影院免费看 | 久久99综合国产精品亚洲首页 | 五月色综合婷婷综合俺来也 | 一区二区三区四区在线不卡高清 | 午夜性刺激免费视频观看不卡专区 | 1024你懂的国产日韩欧美 | 香蕉视频在线观看国产 | 日本免费毛片在线高清看 | 亚洲在线a | 亚洲国产精品嫩草影院久久 | 中国特级黄色毛片 | 奇米成人网 | 国产资源在线看 | 鲁大师视频在线www观看 | 一区二区三区视频在线观看 | 手机看片国产日韩 | 国产成人免费高清视频网址 | 国产日产高清欧美一区二区三区 | 国产福利视频微拍在线 |