欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

在vue-test-utils中mock全局對象怎么用-創(chuàng)新互聯(lián)

小編給大家分享一下在vue-test-utils中mock全局對象怎么用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

在咸寧等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供做網(wǎng)站、網(wǎng)站設(shè)計 網(wǎng)站設(shè)計制作按需網(wǎng)站建設(shè),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站設(shè)計,網(wǎng)絡(luò)營銷推廣,成都外貿(mào)網(wǎng)站建設(shè),咸寧網(wǎng)站建設(shè)費用合理。

vue-test-utils   提供了一種 mock 掉   Vue.prototype   的簡單方式,不但對測試用例適用,也可以為所有測試設(shè)置默認的 mock。

mocks   加載選項

mocks   加載選項   是一種將任何屬性附加到   Vue.prototype   上的方式。這通常包括:

  • $store , for Vuex

  • $router , for Vue Router

  • $t , for vue-i18n

以及其他種種。

vue-i18n   的例子

我們來看一個 vue-i18n   的例子。雖然可以為每個測試用到   createLocalVue   并安裝   vue-i18n ,但那樣可能會讓事情難以處理并引入一堆樣板。首先,組件   <Bilingual>   用到了   vue-i18n :

<template>
 <div class="hello">
  {{ $t("helloWorld") }}
 </div>
</template>

<script>
 export default {
  name: "Bilingual"
 }
</script>

你先在另一個文件中弄好翻譯,然后通過 $t   引用,這就是   vue-i18n   的工作方式。在本次測試中,雖然并不會真正關(guān)心翻譯文件看起來什么樣,不過還是看一看這次用到的:

export default {
 "en": {
  helloWorld: "Hello world!"
 },
 "ja": {
  helloWorld: "こんにちは、世界!"
 }
}

基于這個 locale,正確的翻譯將被渲染出來。我們先不用 mock,嘗試在測試中渲染該組件:

import { shallowMount } from "@vue/test-utils"
import Bilingual from "@/components/Bilingual.vue"

describe("Bilingual", () => {
 it("renders successfully", () => {
  const wrapper = shallowMount(Bilingual)
 })
})

通過 yarn test:unit   運行測試將拋出一堆錯誤堆棧。若仔細端詳輸出則會發(fā)現(xiàn):

[Vue warn]: Error in config.errorHandler: "TypeError: _vm.$t is not a function"

這是因為我們并未安裝 vue-i18n ,所以全局的   $t   方法并不存在。我們試試   mocks   加載選項:

import { shallowMount } from "@vue/test-utils"
import Bilingual from "@/components/Bilingual.vue"

describe("Bilingual", () => {
 it("renders successfully", () => {
  const wrapper = shallowMount(Bilingual, {
   mocks: {
    $t: (msg) => msg
   }
  })
 })
})

現(xiàn)在測試通過了! mocks   選項用處多多,而我覺得最最常用的正是開頭提到過的那三樣。

(譯注:通過這種方式就不能在單元測試中耦合與特定語言相關(guān)的內(nèi)容了,因為翻譯功能實際上已失效,也更無法處理可選參數(shù)等)

使用配置設(shè)置默認的 mocks

有時需要一個 mock 的默認值,這樣就不用為每個測試用例都設(shè)置一遍了??梢杂?vue-test-utils   提供的   config   API 來實現(xiàn)。還是   vue-i18n   的例子:

import VueTestUtils from "@vue/test-utils"

VueTestUtils.config.mocks["mock"] = "Default Mock Value"

這個示例中用到了 Jest,所以我將把默認 mock 描述在 jest.init.js   文件中 -- 該文件會在測試運行前被自動加載。同時我也會導(dǎo)入并應(yīng)用此前用于示例的翻譯對象。

//jest.init.js

import VueTestUtils from "@vue/test-utils"
import translations from "./src/translations.js"

const locale = "en"

VueTestUtils.config.mocks["$t"] = (msg) => translations[locale][msg]

現(xiàn)在盡管還是用了一個 mock 過的 $t   函數(shù),但會渲染一個真實的翻譯了。再次運行測試,這次移除了   mocks   加載選項并用   console.log   打印了   wrapper.html() 。

describe("Bilingual", () => {
 it("renders successfully", () => {
  const wrapper = shallowMount(Bilingual)

  console.log(wrapper.html())
 })
})

測試通過,以下結(jié)構(gòu)被渲染出來:

<div class="hello">
 Hello world!
</div>

以上是“在vue-test-utils中mock全局對象怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

文章名稱:在vue-test-utils中mock全局對象怎么用-創(chuàng)新互聯(lián)
標題網(wǎng)址:http://aaarwkj.com/article8/jcgip.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄手機網(wǎng)站建設(shè)、響應(yīng)式網(wǎng)站、網(wǎng)站營銷、域名注冊小程序開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化
中国吞精囗交免费视频| 人妻熟妇一区二区三区成人| 精品国产一区二区三区av在线| 国产91精品成人在线观看| 日本欧美三级高潮受不了| 九九热久久这里全是精品| 亚洲午夜精品久久久天堂| 午夜激情视频在线网站| 日本高清免费播放一区二区| 亚洲一区有码在线观看| 国产成人国产精品国产三级| 国产实拍之强伦奸在线观看| 好吊毛片一区二区三区| 国产精品亚洲二区三区| 国产大学生吞精在线视频| 一区二区三区欧美日韩在线 | 人妻有码中文字幕在线| 国产成人亚洲精品午夜国产馆| 四虎最新地址在线观看| 精品亚洲韩国一区二区三区| 日韩欧美一区二区大片| 日韩欧美一区二区麻豆| 国产精品美女自拍视频| 蜜臀av中文字幕亚洲| 国产精品人妻在线av| 日韩欧美一区二区黄色| 国产成人激情自拍视频在线观看 | 成人中文字幕av电影| 中文字幕国产精品资源| 亚洲精品视频一区二区| 日韩免费高清不卡视频| 久久亚洲精品国产精品黑人| 91亚洲欧美日韩在线观看| 亚洲精品永久在线观看| 国产精品白嫩初高中害羞小美女| 午夜精品久久99蜜桃| 欧美 日韩一区二区在线| 黄色成人av在线网站| 六月综合激情丁香婷婷色| 国产中文字幕婷婷丁香| 自拍偷拍亚洲另类激情|