Home Web Front-end JS Tutorial Detailed explanation of steps to use Vue Mixin function

Detailed explanation of steps to use Vue Mixin function

Apr 28, 2018 am 11:47 AM
mixin step Detailed explanation

This time I will give you a detailed explanation of the steps to use the Vue Mixin function. What are the precautions when using the Vue Mixin function. The following is a practical case, let's take a look.

After switching to using Typescript to write Vue applications, after a round of baptism of tool chains and dependencies, I finally started to stumble. However, there is a very commonly used function mixin, and there seems to be no official solution yet.

I want to enjoy the flexibility and convenience of mixins, but also want to reap the security brought by the ts type system and the smooth experience of using IntelliSense during development.

vuejs official organization has a 'vue-class-component' and the recommended 'vue-property-decorator', but there is no corresponding implementation. After looking through the former issue, there is a feature that has been pending for a long time and is mixin support.

It’s not a complicated thing, just write one yourself.

Later note: vue-class-component 6.2.0 starts to provide mixins method, which is similar to the implementation idea of ​​this article.

Implementation

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

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

 })

}

Copy after login

Declare VClass as a class constructor for T. At the same time, the static methods (extend/mixin and the like) on Vue's constructor are obtained through Pick, so that the real implementation in the following paragraph can be supported. A new subclass is generated by calling the extend method on a Vue subclass constructor. Class constructor.

1

2

3

4

5

function Mixins<T>(c: VClass<T>, ...traits: Array<VClass<T>>): VClass<T> {

 return c.extend({

  mixins: traits

 })

}

Copy after login

As for ABC, this is purely a manual job of type declaration.

Usage

In actual use:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

import { Component, Vue } from 'vue-property-decorator'

import { Mixins } from '../../util/mixins'

@Component

class 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: `

 <p>

  <h1>{{ title }}</h1>

  <p>Counted: {{ counter }}</p>

 </p>

 `

})

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 1

count to 2

count to 3

calling reidrectTo /otherpage

about to clear disposables

Copy after login

Notice that the DisposableMixin that directly extends Vue is not a valid Vue component, nor can it be used directly Used in the mixins option, if it is to be used by a self-defined component extended by Vue.extend, remember to use Component to wrap it up.

1

2

3

4

const ExtendedComponent = Vue.extend({

 name: 'ExtendedComponent',

 mixins: [Component(DisposableMixin)],

})

Copy after login
Abstract class

Mixins used in business systems are actually more complex in most cases, providing some basic functions, but some parts need to be left to the successors to implement themselves. At this time It is appropriate to use

abstract class.

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

abstract class AbstractMusicPlayer extends Vue {

 abstract audioSrc: string

 playing = false

 togglePlay() {

  this.playing = !this.playing

 }

}

class MusicPlayerA extends AbstractMusicPlayer {

 audioSrc = '/audio-a.mp3'

}

class MusicPlayerB extends AbstractMusicPlayer {

 staticBase = '/statics'

 get audioSrc() {

  return `${this.staticBase}/audio-b.mp3`

 }

}

Copy after login
But abstract classes cannot be instantiated and do not meet the requirement of

{ new(): T }, so they can only be inherited and cannot be mixed in. Due to the same The reason is that abstract classes cannot be decorated by the Component function of 'vue-class-component'.

At this time, we have to write the implemented functions into Mixin, and put the functions to be implemented into the interface and let the specific class implement them.

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

interface IMusicSourceProvider {

 audioSrc: string

}

/**

 * @implements IPlayerImplementation

 */

class PlayerMixin extends Vue {

 /** @abstract */

 audioSrc: string

 logSrc() {

  console.log(this.audioSrc)

 }

}

interface IPlayerImplementation extends IMusicSourceProvider {}

class RealPlayer extends Mixins(PlayerMixin) implements IPlayerImplementation {

 audioSrc = '/audio-c.mp3'

}

Copy after login
This way of deceiving the compiler is actually quite clumsy. If a specific class inherits PlayerMixin but does not explicitly declare to implement IPlayerImplementation, the compiler cannot tell you this error. We can only carefully write comments in the code and hope that users will not forget this.

I believe you have mastered the method after reading the case in this article. For more exciting information, please pay attention to other related articles on the php Chinese website!

Recommended reading:

Jump back to the homepage after sharing the page

##Detailed explanation of the use of watch method in Vue

The above is the detailed content of Detailed explanation of steps to use Vue Mixin function. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to make Google Maps the default map in iPhone How to make Google Maps the default map in iPhone Apr 17, 2024 pm 07:34 PM

The default map on the iPhone is Maps, Apple's proprietary geolocation provider. Although the map is getting better, it doesn't work well outside the United States. It has nothing to offer compared to Google Maps. In this article, we discuss the feasible steps to use Google Maps to become the default map on your iPhone. How to Make Google Maps the Default Map in iPhone Setting Google Maps as the default map app on your phone is easier than you think. Follow the steps below – Prerequisite steps – You must have Gmail installed on your phone. Step 1 – Open the AppStore. Step 2 – Search for “Gmail”. Step 3 – Click next to Gmail app

Steps to upgrade to the latest version of WeChat (Easily master the upgrade method to the latest version of WeChat) Steps to upgrade to the latest version of WeChat (Easily master the upgrade method to the latest version of WeChat) Jun 01, 2024 pm 10:24 PM

WeChat is one of the social media platforms in China that continuously launches new versions to provide a better user experience. Upgrading WeChat to the latest version is very important to keep in touch with family and colleagues, to stay in touch with friends, and to keep abreast of the latest developments. 1. Understand the features and improvements of the latest version. It is very important to understand the features and improvements of the latest version before upgrading WeChat. For performance improvements and bug fixes, you can learn about the various new features brought by the new version by checking the update notes on the WeChat official website or app store. 2. Check the current WeChat version We need to check the WeChat version currently installed on the mobile phone before upgrading WeChat. Click to open the WeChat application "Me" and then select the menu "About" where you can see the current WeChat version number. 3. Open the app

This Apple ID is not yet in use in the iTunes Store: Fix This Apple ID is not yet in use in the iTunes Store: Fix Jun 10, 2024 pm 05:42 PM

When logging into iTunesStore using AppleID, this error saying "This AppleID has not been used in iTunesStore" may be thrown on the screen. There are no error messages to worry about, you can fix them by following these solution sets. Fix 1 – Change Shipping Address The main reason why this prompt appears in iTunes Store is that you don’t have the correct address in your AppleID profile. Step 1 – First, open iPhone Settings on your iPhone. Step 2 – AppleID should be on top of all other settings. So, open it. Step 3 – Once there, open the “Payment & Shipping” option. Step 4 – Verify your access using Face ID. step

Shazam app not working in iPhone: Fix Shazam app not working in iPhone: Fix Jun 08, 2024 pm 12:36 PM

Having issues with the Shazam app on iPhone? Shazam helps you find songs by listening to them. However, if Shazam isn't working properly or doesn't recognize the song, you'll have to troubleshoot it manually. Repairing the Shazam app won't take long. So, without wasting any more time, follow the steps below to resolve issues with Shazam app. Fix 1 – Disable Bold Text Feature Bold text on iPhone may be the reason why Shazam is not working properly. Step 1 – You can only do this from your iPhone settings. So, open it. Step 2 – Next, open the “Display & Brightness” settings there. Step 3 – If you find that “Bold Text” is enabled

Detailed explanation of the steps to obtain Win11 system administrator permissions Detailed explanation of the steps to obtain Win11 system administrator permissions Mar 08, 2024 pm 09:09 PM

Windows 11, as the latest operating system launched by Microsoft, is deeply loved by users. In the process of using Windows 11, sometimes we need to obtain system administrator rights in order to perform some operations that require permissions. Next, we will introduce in detail the steps to obtain system administrator rights in Windows 11. The first step is to click "Start Menu". You can see the Windows icon in the lower left corner. Click the icon to open the "Start Menu". In the second step, find and click "

iPhone screenshots not working: How to fix it iPhone screenshots not working: How to fix it May 03, 2024 pm 09:16 PM

Screenshot feature not working on your iPhone? Taking a screenshot is very easy as you just need to hold down the Volume Up button and the Power button at the same time to grab your phone screen. However, there are other ways to capture frames on the device. Fix 1 – Using Assistive Touch Take a screenshot using the Assistive Touch feature. Step 1 – Go to your phone settings. Step 2 – Next, tap to open Accessibility settings. Step 3 – Open Touch settings. Step 4 – Next, open the Assistive Touch settings. Step 5 – Turn on Assistive Touch on your phone. Step 6 – Open “Customize Top Menu” to access it. Step 7 – Now you just need to link any of these functions to your screen capture. So click on the first

Clock app missing in iPhone: How to fix it Clock app missing in iPhone: How to fix it May 03, 2024 pm 09:19 PM

Is the clock app missing from your phone? The date and time will still appear on your iPhone's status bar. However, without the Clock app, you won’t be able to use world clock, stopwatch, alarm clock, and many other features. Therefore, fixing missing clock app should be at the top of your to-do list. These solutions can help you resolve this issue. Fix 1 – Place the Clock App If you mistakenly removed the Clock app from your home screen, you can put the Clock app back in its place. Step 1 – Unlock your iPhone and start swiping to the left until you reach the App Library page. Step 2 – Next, search for “clock” in the search box. Step 3 – When you see “Clock” below in the search results, press and hold it and

Slow Cellular Data Internet Speeds on iPhone: Fixes Slow Cellular Data Internet Speeds on iPhone: Fixes May 03, 2024 pm 09:01 PM

Facing lag, slow mobile data connection on iPhone? Typically, the strength of cellular internet on your phone depends on several factors such as region, cellular network type, roaming type, etc. There are some things you can do to get a faster, more reliable cellular Internet connection. Fix 1 – Force Restart iPhone Sometimes, force restarting your device just resets a lot of things, including the cellular connection. Step 1 – Just press the volume up key once and release. Next, press the Volume Down key and release it again. Step 2 – The next part of the process is to hold the button on the right side. Let the iPhone finish restarting. Enable cellular data and check network speed. Check again Fix 2 – Change data mode While 5G offers better network speeds, it works better when the signal is weaker

See all articles