在vue中使用export default导出的class类方式
作者:ldz_miantiao 发布时间:2024-04-09 10:48:47
标签:vue,export,default,class类
使用export default导出class类
首先我们要创建一个类并导出
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>
关于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");
/* 第二种方式调用
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"
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
来源:https://blog.csdn.net/qq_40282732/article/details/104343595


猜你喜欢
- 公司数据中心计划将海量数据做一次迁移,同时增加某时间字段(原来是datatime类型,现在增加一个date类型),单表数据量达到6亿多条记录
- 前言本文介绍在 pandas 中如何读取数据行列的方法。数据由行和列组成,在数据库中,一般行被称作记录 (record),列被称作字段 (f
- 原理 QueryCache(下面简称QC)是根据SQL语句来cache的。一个SQL查询如果以select开头,那么MySQL服务器将尝试对
- 写在前面最近正好有音视频编辑的需求,虽然之前粗略的了解过FFmpeg不过肯定是不够用的,借此重新学习下;基本概念ffmpeg概念Fmpeg的
- php中session_id()函数原型及说明session_id()函数说明:stringsession_id([string$id])s
- 一、生成二维码二维码又称二维条码,常见的二维码为QR Code,QR全称Quick Response,是一个近几年来移动设备上超流行的一种编
- 什么是异步?含义 :双方不需要共同的时钟,也就是接收方不知道发送方什么时候发送,所以在发送的信息中就要有提示接收方开始接收的信息,如开始位,
- 为了配置基于 mod_python 的 Django,首先要安装有可用的 mod_python 模块的 Apache。 这通常意味着应该有一
- 写在前面vue中关于插槽的文档说明很短,语言又写的很凝练,再加上其和methods,data,computed等常用选项使用频率、使用先后上
- 本文实例讲述了Python中函数的参数定义和可变参数用法。分享给大家供大家参考。具体如下:刚学用Python的时候,特别是看一些库的源码时,
- 先看看关于call()的官方解释,“调用一个对象的一个方法,以另一个对象替换当前对象。”,看了这样的解释,或许让你更摸不着头脑了。看例子:v
- 需要使用到的文件wxapp.py, read_file.py, setup.py#!/usr/bin/env python# -*- cod
- 一、按索引取数据①tf.gather()输入参数:数据、维度、索引例:设数据是[4,35,8],4个班级,每个班级35个学生,每个学生8门课
- 最近需要做一个围棋识别的项目,首先要将棋盘位置定位出来,效果图如下:效果图原图中间处理效果最终结果思路分析我们利用python opencv
- Python转json时出现中文乱码设置报文头# -*- coding:gbk -*- 连接数据库设置编码mysql = MyS
- web开发中避免不了运行环境的搭建,个人认为这是没有什么技术含量而又浪费时间的工作.所以将环境搭建的步骤记录下来,希望可以帮到有需要的朋友少
- getpass模块的使用:在python中实现密码密文需要导入getpass模块,在python中要使用内置模块的话,需要使用import进
- pip install命令用于安装扩展库,由于安装扩展库需要从国外网站下载,速度较慢,可以使用-i选项设置临时使用国内的镜像网站。命令格式:
- 校验是否全由数字组成function isDigit(s) { var patrn=/^[0-9]{1,20}$/; if (!patrn.
- * 页爬取是爬虫学习中的一个难点。本文将以知名插画网站pixiv为例,简要介绍 * 页爬取的方法。写在前面本代码的功能是输入画师的pixi