目录使用export default导出class类关于export的多种导出形式1、文件中存在多个export的时候2、使用export default时3、单个export且不使
首先我们要创建一个类并导出
class win {
getProcessInfo() {
return 233;
}
}
export default new win(); //用的是export default方法,并且导出的时候就已经实例化了
在Vue文件中引用
.....
..这里是template...
.....
<script>
import win from "这里是路径";
export default {
data() {
return {};
},
methods: {
getProcessInfoFn() {
console.log(win.getProcessInfo()); //233
}
}
};
</script>
//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'
@Component
export default class ceshi extends Vue {
private mounted(){
new Modulea("模块A");
new Moduleb("模块B");
new Modulec("模块C");
}
}
</script>
<style lang='less' scoped>
</style>
//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>
引用方式同第一种情况
//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
}
//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>
//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>
//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>
//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>
//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"
以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。
--结束END--
本文标题: 在vue中使用export default导出的class类方式
本文链接: https://lsjlt.com/news/144525.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-01-12
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0