VUE导入、导出模块

webpack 支持 ESModel 规范和 CommonJS 规范

一、ESModel 规范

  • ESModel 模块导入方式:import
  • ESModel 模块导出方式:export、export default

1. export 导出 和 import {}、import * as 导入

javascript 复制代码
export const name = 'alias'
export const age = () => {
  return 18
}
xml 复制代码
<template>
  <div id="app">
  </div>
</template>

<script>
import { name, age } from './utils/user'
import * as user from './utils/user'
export default {
  name: 'App',
  created() {
    console.log(name) // alias
    console.log(age()) // 18
    console.log(user.name) // alias
    console.log(user.age()) // 18
  },
}
</script>

2. export default 导出 和 import 导入

javascript 复制代码
const name = 'alias'
const age = () => {
  return 18
}

export default { name, age }
xml 复制代码
<template>
  <div id="app">
  </div>
</template>

<script>
import user from './utils/user'
export default {
  name: 'App',
  created() {
    console.log(user.name) // alias
    console.log(user.age()) // 18
  },
}
</script>

二、CommonJS 规范

  • CommonJS 模块导入方式:require
  • CommonJS 模块导出方式:exports、module.exports

1. exports. 导出 和 require 导入

ini 复制代码
const name = 'alias'
const age = () => {
  return 18
}
exports.name = name
exports.age = age
xml 复制代码
<template>
  <div id="app">
  </div>
</template>

<script>
const user = require('./utils/user')

export default {
  name: 'App',
  created() {
    console.log(user.name) // alias
    console.log(user.age()) // 18
  },
}
</script>

2. module.exports = {} 导出 和 require 导入

ini 复制代码
const name = 'alias'
const age = () => {
  return 18
}

module.exports = {
  name,
  age,
}
xml 复制代码
<template>
  <div id="app">
  </div>
</template>

<script>
const user = require('./utils/user')

export default {
  name: 'App',
  created() {
    console.log(user.name) // alias
    console.log(user.age()) // 18
  },
}
</script>
相关推荐
coderHing[专注前端]4 分钟前
告别 try/catch 地狱:用三元组重新定义 JavaScript 错误处理
开发语言·前端·javascript·react.js·前端框架·ecmascript
UIUV21 分钟前
JavaScript中this指向机制与异步回调解决方案详解
前端·javascript·代码规范
momo10021 分钟前
IndexedDB 实战:封装一个通用工具类,搞定所有本地存储需求
前端·javascript
liuniansilence21 分钟前
🚀 高并发场景下的救星:BullMQ如何实现智能流量削峰填谷
前端·分布式·消息队列
再花21 分钟前
在Angular中实现基于nz-calendar的日历甘特图
前端·angular.js
GISer_Jing33 分钟前
今天看了京东零售JDS的保温直播,秋招,好像真的结束了,接下来就是论文+工作了!!!加油干论文,学&分享技术
前端·零售
Mapmost40 分钟前
【高斯泼溅】如何将“歪头”的3DGS模型精准“钉”在地图上,杜绝后续误差?
前端
京东云开发者1 小时前
AI Infra平台市场报告:京东云稳居前三
程序员
废春啊1 小时前
前端工程化
运维·服务器·前端
爱上妖精的尾巴1 小时前
6-9 WPS JS宏Map、 set、get、delete、clear()映射的添加、修改、删除
前端·wps·js宏·jsa