国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

在 Typescript 中使用可被復(fù)用的 Vue Mixin功能

2024-05-06 15:19:57
字體:
供稿:網(wǎng)友

轉(zhuǎn)到用 Typescript 寫 Vue 應(yīng)用以后,經(jīng)過一輪工具鏈和依賴的洗禮,總算蹣跚地能走起來了,不過有一個(gè)很常用的功能 mixin,似乎還沒有官方的解決方案。

既想享受 mixin 的靈活和方便,又想收獲 ts 的類型系統(tǒng)帶來的安全保障和開發(fā)時(shí)使用 IntelliSense 的順滑體驗(yàn)。

vuejs 官方組織里有一個(gè) 'vue-class-component' 以及連帶推薦的 'vue-property-decorator',都沒有相應(yīng)實(shí)現(xiàn)。翻了下前者的 issue,有一條掛了好些時(shí)間的待做 feature 就是 mixin 的支持。

也不是什么復(fù)雜的事,自己寫一個(gè)吧。

后注:vue-class-component 6.2.0 開始提供 mixins 方法,和本文的實(shí)現(xiàn)思路相似。

實(shí)現(xiàn)

import Vue, { VueConstructor } from 'vue'export type VClass<T> = { new(): T} & Pick<VueConstructor, keyof VueConstructor>/** * mixins for class style vue component */function Mixins<A>(c: VClass<A>): VClass<A>function Mixins<A, B>(c: VClass<A>, c1: VClass<B>): VClass<A&B>function Mixins<A, B, C>(c: VClass<A>, c1: VClass<B>, c2: VClass<C>): VClass<A&B&C>function Mixins<T>(c: VClass<T>, ...traits: Array<VClass<T>>): VClass<T> { return c.extend({  mixins: traits })}

聲明 VClass<T> 可作為 T 的類構(gòu)造器。同時(shí)通過 Pick 拿到 Vue 的構(gòu)造器上的靜態(tài)方法(extend/mixin 之類),如此才能夠支持下面這段中的真正實(shí)現(xiàn),通過調(diào)用一個(gè) Vue 的子類構(gòu)造器上的 extend 方法生成新的子類構(gòu)造器。

function Mixins<T>(c: VClass<T>, ...traits: Array<VClass<T>>): VClass<T> { return c.extend({  mixins: traits })}

至于 ABC 這個(gè)純粹是類型聲明的體力活了。

使用

實(shí)際使用時(shí):

import { Component, Vue } from 'vue-property-decorator'import { Mixins } from '../../util/mixins'@Componentclass PageMixin extends Vue { title = 'Test Page' redirectTo(path: string) {  console.log('calling reidrectTo', path)  this.$router.push({ path }) }}interface IDisposable { dispose(...args: any[]): any}class DisposableMixin extends Vue { _disposables: IDisposable[] created() {  console.log('disposable mixin created');  this._disposables = [] } beforeDestroy() {  console.log('about to clear disposables')  this._disposables.map((d) => {   d.dispose()  })  delete this._disposables } registerDisposable(d: IDisposable) {  this._disposables.push(d) }}@Component({ template: ` <div>  <h1>{{ title }}</h1>  <p>Counted: {{ counter }}</p> </div> `})export default class TimerPage extends Mixins(PageMixin, DisposableMixin) { counter = 0 mounted() {  const timer = setInterval(() => {   if (this.counter++ >= 3) {    return this.redirectTo('/otherpage')   }   console.log('count to', this.counter);  }, 1000)  this.registerDisposable({   dispose() {    clearInterval(timer)   }  }) }}count to 1count to 2count to 3calling reidrectTo /otherpageabout to clear disposables            
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 务川| 诸城市| 丰台区| 保康县| 临清市| 安陆市| 曲靖市| 湄潭县| 依安县| 高安市| 农安县| 濮阳县| 昆山市| 寻甸| 健康| 清水河县| 吕梁市| 葫芦岛市| 海林市| 三都| 腾冲县| 赞皇县| 白银市| 贵港市| 平度市| 新龙县| 黄骅市| 九龙县| 金坛市| 新闻| 稻城县| 平罗县| 石嘴山市| 莎车县| 舒兰市| 旬邑县| 巴楚县| 台中市| 巢湖市| 西藏| 穆棱市|