溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

在vue中怎么使用export?default導出的class類

發(fā)布時間:2022-03-31 10:22:09 來源:億速云 閱讀:1683 作者:iii 欄目:開發(fā)技術(shù)

本文小編為大家詳細介紹“在vue中怎么使用export default導出的class類”,內(nèi)容詳細,步驟清晰,細節(jié)處理妥當,希望這篇“在vue中怎么使用export default導出的class類”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

使用export default導出class類

首先我們要創(chuàng)建一個類并導出

class win {
  getProcessInfo() {
    return 233;
  }
}
export default new win(); //用的是export default方法,并且導出的時候就已經(jīng)實例化了

在vue文件中引用

.....
..這里是template...
.....
<script>
import win from "這里是路徑";
export default {
  data() {
    return {};
  },
  methods: {
    getProcessInfoFn() {
      console.log(win.getProcessInfo()); //233
    }
  }
};
</script>

關(guān)于export的多種導出形式

  • require:node和es6都支持的引入

  • export/import:只有es6 支持的導出引入

  • module.exports/exports:只有 node 支持的導出

1、文件中存在多個export的時候

//module.ts文件
export class Modulea{
    constructor(public params:string){
        console.log(params);
    }
}
export class Moduleb{
    constructor(public params:string){
        console.log(params);
    }
}
export class Modulec{
    constructor(public params:string){
        console.log(params);
    }
}
//ceshi.vue文件
<template>
    <div class='ceshi'>
        
    </div>
</template>
 
<script lang='ts'>
import { Component,Vue } from 'vue-property-decorator';
import {Modulea,Moduleb,Modulec} from '@/assets/module.ts'
/* 
第二種方式
import * as module from '@/assets/module.ts'
*/
@Component
export default class ceshi extends Vue {
    private mounted(){
        new Modulea("模塊A");
        new Moduleb("模塊B");
        new Modulec("模塊C");
        /* 第二種方式調(diào)用
        new module.Modulea("模塊A");
        new module.Moduleb("模塊B");
        new module.Modulec("模塊C");
        */
    }
}
</script>
 
<style lang='less' scoped>
    
</style>

2、使用export default時

//module.ts文件
export default class Modulea{
    constructor(public params:string){
        console.log(params);
    }
    newB(params:string){
        new Moduleb(params);
    }
    newC(params:string){
        new Modulec(params)
    }
}
class Moduleb{
    constructor(public params:string){
        console.log(params);
    }
}
class Modulec{
    constructor(public params:string){
        console.log(params);
    }
}
<template>
    <div class='ceshi'>
        
    </div>
</template>
 
<script lang='ts'>
import { Component,Vue } from 'vue-property-decorator';
import module from '@/assets/module.ts'
@Component
export default class ceshi extends Vue {
    private mounted(){
        let modulea = new module("模塊A");
        modulea.newB("模塊B");
        modulea.newC("模塊C");
    }
}
</script>
 
<style lang='less' scoped>
    
</style>

3、單個export且不使用default時

引用方式同第一種情況

//module.ts
class Modulea{
    constructor(public params:string){
        console.log(params);
    }
    newB(params:string){
        new Moduleb(params);
    }
    newC(params:string){
        new Modulec(params)
    }
}
class Moduleb{
    constructor(public params:string){
        console.log(params);
    }
}
class Modulec{
    constructor(public params:string){
        console.log(params);
    }
}
export {
    Modulea,Moduleb,Modulec
}

4、單個export使用default時

//module.ts文件
class Modulea{
    constructor(public params:string){
        console.log(params);
    }
    newB(params:string){
        new Moduleb(params);
    }
    newC(params:string){
        new Modulec(params)
    }
}
class Moduleb{
    constructor(public params:string){
        console.log(params);
    }
}
class Modulec{
    constructor(public params:string){
        console.log(params);
    }
}
export default {
    Modulea,Moduleb,Modulec
}
//ceshi.vue文件
<template>
    <div class='ceshi'>
        
    </div>
</template>
 
<script lang='ts'>
import { Component,Vue } from 'vue-property-decorator';
import module from '@/assets/module.ts'
@Component
export default class ceshi extends Vue {
    private mounted(){
        new module.Modulea("模塊A");
        new module.Moduleb("模塊B");
        new module.Modulec("模塊C");
    }
}
</script>
 
<style lang='less' scoped>
    
</style>

5、使用module.exports時

//module.ts文件
class Modulea{
    constructor(public params:string){
        console.log(params);
    }
    newB(params:string){
        new Moduleb(params);
    }
    newC(params:string){
        new Modulec(params)
    }
}
class Moduleb{
    constructor(public params:string){
        console.log(params);
    }
}
class Modulec{
    constructor(public params:string){
        console.log(params);
    }
}
module.exports = {
    Modulea,Moduleb,Modulec
}
//ceshi.vue文件
<template>
    <div class='ceshi'>
        
    </div>
</template>
 
<script lang='ts'>
import { Component,Vue } from 'vue-property-decorator';
let module = require('@/assets/module.ts');
@Component
export default class ceshi extends Vue {
    private mounted(){
        new module.Modulea("模塊A");
        new module.Moduleb("模塊B");
        new module.Modulec("模塊C");
    }
}
</script>
 
<style lang='less' scoped>
    
</style>

6、exports

//module.ts文件
class Modulea{
    constructor(public params:string){
        console.log(params);
    }
    newB(params:string){
        new Moduleb(params);
    }
    newC(params:string){
        new Modulec(params)
    }
}
class Moduleb{
    constructor(public params:string){
        console.log(params);
    }
}
class Modulec{
    constructor(public params:string){
        console.log(params);
    }
}
exports.ex= {
    Modulea,Moduleb,Modulec
}
//ceshi.vue文件
<template>
    <div class='ceshi'>
        
    </div>
</template>
 
<script lang='ts'>
import { Component,Vue } from 'vue-property-decorator';
let module = require('@/assets/module.ts');
@Component
export default class ceshi extends Vue {
    private mounted(){
        new module.ex.Modulea("模塊A");
        new module.ex.Moduleb("模塊B");
        new module.ex.Modulec("模塊C");
    }
}
</script>
 
<style lang='less' scoped>
    
</style>

7、exports第二種寫法

//module.ts文件
class Modulea{
    constructor(public params:string){
        console.log(params);
    }
    newB(params:string){
        new Moduleb(params);
    }
    newC(params:string){
        new Modulec(params)
    }
}
class Moduleb{
    constructor(public params:string){
        console.log(params);
    }
}
class Modulec{
    constructor(public params:string){
        console.log(params);
    }
}
exports.Modulea = Modulea
exports.Moduleb = Moduleb
exports.Modulec = Modulec
<template>
    <div class='ceshi'>
        
    </div>
</template>
 
<script lang='ts'>
import { Component,Vue } from 'vue-property-decorator';
let module = require('@/assets/module.ts');
@Component
export default class ceshi extends Vue {
    private mounted(){
        new module.Modulea("模塊A");
        new module.Moduleb("模塊B");
        new module.Modulec("模塊C");
    }
}
</script>
 
<style lang='less' scoped>
    
</style>

8、混合導出

//default.js
function add(a,b){
    return a + b;
}
 
function dist(a,b){
    return a - b;
}
export { dist }
export default add;
 
//index.js
import add,{dist} from "./default.js"

讀到這里,這篇“在vue中怎么使用export default導出的class類”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領(lǐng)會,如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI