webpack-nodejs-模块系统

其实,Module.exports才是真正的接口,exports只不过是它的一个辅助工具。 最终返回给调用的是Module.exports而不是exports。

所有的exports收集到的属性和方法,都赋值给了Module.exports。当然,这有个前提,就是Module.exports本身不具备任何属性和方法。如果,Module.exports已经具备一些属性和方法,那么exports收集来的信息将被忽略

  1. //utils.js
  2. var path = require('path')
  3. var config = require('../config')
  4. var ExtractTextPlugin = require('extract-text-webpack-plugin')
  5. exports.assetsPath = function (_path) {
  6. var assetsSubDirectory = process.env.NODE_ENV === 'production'
  7. ? config.build.assetsSubDirectory
  8. : config.dev.assetsSubDirectory
  9. return path.posix.join(assetsSubDirectory, _path)
  10. }
  11. //webpack.base.conf.js
  12. var path = require('path')
  13. var utils = require('./utils')
  14. module.exports = {
  15. entry: {
  16. app: './src/main.js'
  17. },
  18. ...
  19. module: {
  20. rules: [
  21. ...
  22. {
  23. test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
  24. loader: 'url-loader',
  25. query: {
  26. limit: 10000,
  27. name: utils.assetsPath('fonts/[name].[hash:7].[ext]')
  28. }
  29. }
  30. ]
  31. }
  32. }
  1. seajs js模块管理很类似
  2. //lib/dialog/main.js
  3. define(function(require, exports, module) {
  4. function Dialog() {};
  5. Dialog.prototype.init = function(strConfig) {
  6. return $.dialog(strConfig);
  7. };
  8. Dialog.prototype.dialogClose = function(dialogId) {
  9. $.dialog.list[dialogId].close();
  10. };
  11. .
  12. .
  13. .
  14. module.exports = Dialog;
  15. }
  16. //hospitalFE-finance-invoice.js
  17. var Dialog = require('dialog'), popWin = new Dialog ();
  18. //config.js
  19. seajs.config({
  20. // 映射,添加版本号
  21. map: [[/^(.*\.(?:css|js))$/i, '$1?v=3.0.3p1t5']],
  22. // 别名配置
  23. alias: {
  24. 'jquery': 'lib/jquery/src/jquery-1.10.1.min',
  25. 'dialog': 'lib/dialog/main', // 对话框
  26. },
  27. // 插件
  28. // plugins: ['shim', 'text', 'debug', 'nocache'], // for development
  29. // 预加载项
  30. preload: ["jquery"],
  31. // 文件编码
  32. charset: 'utf-8'
  33. });

ES6模块的 import 和 export 用法总结

  1. ES6模块主要有两个功能:exportimport
  2. export 用于对外输出本模块(一个文件可以理解为一个模块)变量的接口
  3. import 用于在一个模块中加载另一个含有export接口的模块。
  4. 假设ab文件在同一目录下
  5. //a.js
  6. var sex="boy";
  7. var echo=function(value){
  8.   console.log(value)
  9. }
  10. export {sex,echo}
  11. //通过向大括号中添加sex,echo变量并且export输出,就可以将对应变量值以sex、echo变量标识符形式暴露给其他文件而被读取到
  12. //不能写成export sex这样的方式,如果这样就相当于export "boy",外部文件就获取不到该文件的内部变量sex的值,因为没有对外输出变量接口,只是输出的字符串。
  13. //b.js
  14. //通过import获取a.js文件的内部变量,{}括号内的变量来自于a.js文件export出的变量标识符。
  15. import {sex,echo} from "./a.js"
  16. console.log(sex) // boy
  17. echo(sex) // boy
  18. 前面的例子可以看出,b.js使用import命令的时候,用户需要知道a.js所暴露出的变量标识符,否则无法加载。
  19. 可以使用export default命令,为模块指定默认输出,这样就不需要知道所要加载模块的变量名。
  20. //a.js
  21. var sex="boy";
  22. export default sexsex不能加大括号)
  23. 实例:
  24. var config={...};
  25. export default function getConfig() {
  26. return config;
  27. }
  28. //原本直接export sex外部是无法识别的,加上default就可以了.但是一个文件内最多只能有一个export default。
  29. //其实此处相当于为sex变量值"boy"起了一个系统默认的变量名default,自然default只能有一个值,
  30. //所以一个文件内不能有多个export default。
  31. // b.js
  32. //本质上,a.js文件的export default输出一个叫做default的变量,然后系统允许你为它取任意名字。
  33. //所以可以为import的模块起任何变量名,且不需要用大括号包含
  34. import any from "./a.js"
  35. import any12 from "./a.js"
  36. 实例:
  37. import getConfig from '../utils/config';
  38. console.log(any,any12) // boy,boy

理解exports的更多相关文章

  1. NODE.JS exports require理解

    node.js exports 的作用是什么? 因为A.js文件想访问B.js文件中的类或函数,是不能直接访问的.为了解决这个问题 node.js 产生了 exports ,exports 实际可以理 ...

  2. nodeJS中exports和mopdule.exports的区别

    每一个node.js执行文件,都自动创建一个module对象,同时,module对象会创建一个叫exports的属性,初始化的值是 {} module.exports = {}; Node.js为了方 ...

  3. (译)Node.js的模块-exports和module.exports

    原文标题:Node.js Module – exports vs module.exports 原文链接:http://www.hacksparrow.com/node-js-exports-vs-m ...

  4. 【nodejs】exports 和 module.exports 的区别

    require 用来加载代码,而 exports 和 module.exports 则用来导出代码.但很多新手可能会迷惑于 exports 和 module.exports 的区别,为了更好的理解 e ...

  5. 深入理解node.js的module.export 和 export方法的区别

    你肯定非常熟悉nodejs模块中的exports对象,你可以用它创建你的模块.例如:(假设这是rocker.js文件) exports.name = function() { console.log( ...

  6. module.exports和exports

    require 用来加载代码,而 exports 和 module.exports 则用来导出代码.但很多新手可能会迷惑于 exports 和 module.exports 的区别,为了更好的理解 e ...

  7. 关于exports 和 module.exports

    本文来源为node.js社区附上链接 http://cnodejs.org/topic/5231a630101e574521e45ef8 require 用来加载代码,而 exports 和 modu ...

  8. module中module.exports与exports的区别(转)

    转https://cnodejs.org/topic/55ccace5b25bd72150842c0a require 用来加载代码,而 exports 和 module.exports 则用来导出代 ...

  9. Node.js、express、mongodb 入门(基于easyui datagrid增删改查)

    前言 从在本机(win8.1)环境安装相关环境到做完这个demo大概不到两周时间,刚开始只是在本机安装环境并没有敲个Demo,从周末开始断断续续的想写一个,按照惯性思维就写一个增删改查吧,一方面是体验 ...

随机推荐

  1. Bootstrap历练实例:popover插件中的方法

    方法 下面是一些弹出框(Popover)插件中有用的方法: 方法 描述 实例 Options: .popover(options) 向元素集合附加弹出框句柄. $().popover(options) ...

  2. Mysql--select基础查询

    基本语法:select 查询列表 from 表名 查询列表可以是表中字段.常量值.表达式.函数:查询的结果是一个虚拟的表格. 注意: ①sql语言大小写不敏感 ②关键字不能分行或略写 ③一般书写方式为 ...

  3. MYSQL 自定义排序

    在mysql order by排序中,大多数情况下仅使用默认排序规则就够了:字符串按字典顺序,数字按大小等等.可有时候,某个字段是有自身业务含义的,比如 type(1,2,3)可能表示早/中/晚,如果 ...

  4. 自定义token,保存到客户端的cookie中,

    自定义token #原理自定义token,放入cookie中,不用存数据库 #token定义方式 >>>>> "加密字符串"|登陆用户id|用户登陆时 ...

  5. Python9-IO模型-day41

    # 进程:启动多个进程,进程之间是由操作系统负责调用# 线程:启动多个线程,真正由被cpu执行的最小单位实际是线程# 开启一个线程,创建一个线程,寄存器.堆栈# 关闭一个线程# 协程# 本质上是一个线 ...

  6. Codeforces Round #461 (Div. 2) C. Cave Painting

    C. Cave Painting time limit per test 1 second memory limit per test 256 megabytes Problem Descriptio ...

  7. (ADO.NET)关于C#中“配置”sqlite问题

    配置打引号,只是因为觉得只是一些小问题,在此记录一下,第一次遇到还真有点手足无措,昨天到今天~终于可以开始放肆的写sqlite了. 好,第一个问题是引用已下载的system.data.sqlite.d ...

  8. (WPF&Silverlight)silverlight自定义控件

    2个半小时弄懂了自定义控件是怎么回事儿. 在silverlight中创建一个UserControl,把上面sliderbar的外观和功能都封装在里面. 以自定义控件mapslider控件为例: 1.首 ...

  9. Intellij Idea 创建JavaWeb项目

    折腾Tomcat折腾了两个晚上,第一个晚上怎么都进不了Tomcat的首页,第二个晚上进去了,但是新建的Web项目,在浏览器中运行,总是 Error on Apache Tomcat: The requ ...

  10. Android 服务入门

    前言:硬着头皮把数据库SQLite看完了,接下来就是android服务了,因为自己本身就是菜鸟,所以呢,也只是做做笔记,技术上的东西就别指望我了. 1.什么是服务呢?举个例子,百度地图,美团外卖,OF ...