偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

以更好的方式使用 Vue Mixins

開(kāi)發(fā) 開(kāi)發(fā)工具
Mixin是一個(gè)有用的工具,但它會(huì)使我們的項(xiàng)目特別是在大項(xiàng)目中變得更加復(fù)雜、不靈活和不透明。使用這種方法是一種很好的實(shí)踐,可以更加明確mixin含義并避免一些由于不明確導(dǎo)致的bug。

Mixin 組件在項(xiàng)目中經(jīng)常被用來(lái)重用一些業(yè)務(wù)邏輯,但它們有一些不確定的細(xì)微差別,這在項(xiàng)目開(kāi)發(fā)中越來(lái)越明顯。我偶爾也會(huì)遇到這種情況,它們會(huì)給代碼庫(kù)的重構(gòu)或新功能的開(kāi)發(fā)帶來(lái)困難。

在介紹我的方法之前,我想先介紹一下使用mixins的優(yōu)點(diǎn)和缺點(diǎn)。

優(yōu)點(diǎn)

  • 擴(kuò)展了代碼重用的DRY原則。我們可以在不同的組件中重復(fù)使用相同的業(yè)務(wù)邏輯。
  • 我們可以把 mixin 作為一個(gè)全局性的 mixin,與所有的組件共享上下文。

缺點(diǎn)

  • 使用mixins的組件的邏輯不透明。
  • 可重寫(xiě)的上下文,我們必須注意不要因?yàn)橄嗤拿Q覆蓋一些Mixin的方法,getter或數(shù)據(jù);

缺點(diǎn)并不是避免使用 mixins 的一個(gè)關(guān)鍵原因,但我們應(yīng)該了解它們。建議使用基于這些技巧的方式來(lái)減少缺點(diǎn)所帶來(lái)的影響。

在 method、getter、value和 props 名字開(kāi)頭使用前綴。它展示了 mixin 相關(guān)的功能。使用這個(gè)技巧可以讓我們輕松地分離組件 props 和 mixin props。例如:$<mixinName>_<(prop|method|value)>。

export default {
props: {
$impressionsMixin_page: {
type: Number,
required: true
},
$impressionsMixin_listingId: {
type: Number,
required: true
},
$impressionsMixin_itemId: {
type: Number,
required: true
}
},
data() {
return {
$impressionsMixin_observer: null,
$impressionsMixin_timeout: null,
$impressionsMixin_eventObject: null
};
},
methods: {
$impressionsMixin_getObserverOptions() {
// ...
},
$impressionsMixin_setImpressionObserver() {
// ...
},
$impressionsMixin_resetImpressionObserver() {
// ...
},
$impressionsMixin_logImpression() {
// ...
}
}
};

在父組件中這樣使用:

<template>
<div id="app">
<ListingItem
v-for="item in items"
:key="item.id"
:item="item"
textAlign="left"
:$impressionsMixin_page="page"
:$impressionsMixin_itemId="item.id"
:$impressionsMixin_listingId="listingId"
/>
</div>
</template>

我不喜歡在全局mixin中使用前綴。通常,這些方法和值的名稱是明確的,并且它們的功能不會(huì)在項(xiàng)目的其他部分重復(fù),所以不需要為它們添加前綴。

export default {
config() {
// ...
},
user() {
// ...
},
isMobile() {
// ...
},
isTablet() {
// ...
},
isDesktop() {
// ...
}
};

該方式的優(yōu)點(diǎn):

  • Mixins的方法或?qū)傩钥梢苑奖愕乇籌DE自動(dòng)完成使用。
  • 使用前綴可以避免組件的方法意外覆蓋mixin方法和屬性。
  • 大項(xiàng)目中的開(kāi)發(fā)者對(duì)組件代碼的透明和方便的閱讀。

總結(jié)

Mixin是一個(gè)有用的工具,但它會(huì)使我們的項(xiàng)目特別是在大項(xiàng)目中變得更加復(fù)雜、不靈活和不透明。使用這種方法是一種很好的實(shí)踐,可以更加明確mixin含義并避免一些由于不明確導(dǎo)致的bug。

作者:knaagar 譯者:前端小智

來(lái)源:medium 原文:https://medium.com/@artem.holinka/use-vue-js-mixins-in-a-better-way-11e4ff774763。

責(zé)任編輯:姜華 來(lái)源: 今日頭條
相關(guān)推薦

2017-09-21 08:31:45

閃存陣列方式

2012-07-25 13:23:32

ibmdw

2019-07-25 08:50:39

Windows 10設(shè)置性能

2024-05-15 08:20:08

GradleMaven工具

2021-08-30 12:25:12

Python序列化函數(shù)

2023-08-22 13:18:00

Web 開(kāi)發(fā)CSS

2019-12-12 10:46:15

Kubernetes容器系統(tǒng)

2024-10-29 12:54:27

2022-02-07 08:58:54

DCIM數(shù)據(jù)中心

2022-01-19 22:18:56

Vue.jsVue SPA開(kāi)發(fā)

2015-08-03 10:41:52

大數(shù)據(jù)

2020-07-29 11:06:16

存儲(chǔ)備份IT

2010-04-13 08:49:08

JavaLombokJavabean

2021-03-26 09:00:00

開(kāi)發(fā)框架React

2020-12-28 08:29:47

Vuecss框架

2014-04-21 10:14:52

PromisesJavaScript

2025-05-06 03:30:00

AIVueVite

2020-05-08 11:24:21

物聯(lián)網(wǎng)醫(yī)療技術(shù)

2014-12-22 16:16:40

Hyper-V

2022-12-30 11:05:40

Rust代碼
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)