Detailed explanation of exports in js
This article mainly shares with you the detailed explanation of exports in js, mainly in the form of code. I hope it can help everyone.
Related video recommendations: 1.JavaScript Quick Start_Jade Girl Heart Sutra Series
Related manual recommendations: 1.JavaScript Chinese Reference Manual
Writing 1
exports.hello = function(){ console.log(‘world’); }
Writing 2
var f = { hello : function(){ console.log(‘world’); } } module.exports = f;
Suppose we The file name of this module written is hello.js. Execute the following code
var h = require(‘hello’); h.hello();
For the above two writing methods, the result obtained after executing this code is the same.
module.exports:
For example:
1,
//a.js module.exports = ['aaa',18] //b.js var a= require('a')console.log(a[1]) //输出18
2,
//a.js module.exports =function(){ this.show=function(){ console.log('hahah~'); } } //b.js var a= require('a'); var obj = new a();obj .show();//输出hahah~ module.exports
My understanding is: you assign something to module.exports, and you will get something after require
exports : //a.js exports.show =function(){ console.log('hahah~'); } //b.js var a= require('a'); a.show();//输出hahah~
exports is already an object, you can add attributes to this object , what you get after require is this exports object.
But you cannot assign a new object to exports, such as exports={}
It should also be noted that if module.exports already has content, then all operations of exports will be invalid. Remember
Let’s talk about prototype again. What is prototype used for? It is to add attributes to the prototype. The prototype is like the parent class in C++. Let me give you another example
1,
//a.js module.exports =function(){ } module.exports.prototype.show = function(){ console.log('hahah~'); } //b.js var a= require('a'); var obj = new a() obj.show()//输出hahah~
Finally, let’s talk about class methods. When it comes to classes, module.exports must be used.
Chestnuts are here
1,
//a.js module.exports =function(){ } module.exports.show = function(){ console.log('hahah~'); } //b.js var a= require('a'); a.show()//输出hahah~ ##module.exports与exports的区别
Each node.js execution file automatically creates a module object. At the same time, the module object will create a module called The attribute of exports, the initialized value is {}
module.exports = {}; Node.js为了方便地导出功能函数,node.js会自动地实现以下这个语句 foo.js exports.a = function(){ console.log('a') } exports.a = 1 test.js var x = require('./foo'); console.log(x.a)
Seeing this, I believe everyone has seen the answer, exports refers to the value of module.exports.
When module.exports is changed, exports will not be changed, and when the module is exported, the actual export execution is module.exports, not exports
Look at the following example
foo.js exports.a = function(){ console.log('a') } module.exports = {a: 2} exports.a = 1 test.js var x = require('./foo'); console.log(x.a) result: 2
exports becomes invalid after module.exports is changed.
Are you starting to feel a little enlightened? Here are some commonly seen usage methods in open source modules.
##module.exports = View function View(name, options) { options = options || {}; this.name = name; this.root = options.root; var engines = options.engines; this.defaultEngine = options.defaultEngine; var ext = this.ext = extname(name); if (!ext && !this.defaultEngine) throw new Error('No default engine was specified and no extension was provided.'); if (!ext) name += (ext = this.ext = ('.' != this.defaultEngine[0] ? '.' : '') + this.defaultEngine); this.engine = engines[ext] || (engines[ext] = require(ext.slice(1)).__express); this.path = this.lookup(name); } module.exports = View;
There is a saying in javascript that function is an object, View is an object, module.export =View, which is equivalent to exporting the entire view object.
When an external module calls it, it can call all methods of View. However, it should be noted that only static methods of View can be called. Methods created by prototype are private methods of View.
foo.js function View(){ } View.prototype.test = function(){ console.log('test') } View.test1 = function(){ console.log('test1') } module.exports = View test.js var x = require('./foo'); console.log(x) //{ [Function: View] test1: [Function] } console.log(x.test) //undefined console.log(x.test1) //[Function] x.test1() //test1 ##var app = exports = module.exports = {};
In fact, when we understand the principle, it is not difficult to understand that this way of writing is a bit redundant. In fact, it is to ensure that the initialization environment of the module is clean. At the same time, it is also convenient for us. Even after changing the object pointed to by module.exports, we can still use the characteristics of exports
exports = module.exports = createApplication; /** * Expose mime. */ exports.mime = connect.mime;
Example, in which module.exports = createApplication changes module.exports, making exports invalid , let it restore its original characteristics through the exports = module.exports method.
##exports.init= function(){}
This is the simplest and directly exported module init method.
##var mongoose = module.exports = exports = new Mongoose;
It has multiple functions, but based on the above description, you should not be able to get the answer.
The above is the detailed content of Detailed explanation of exports in js. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics











How to use WebSocket and JavaScript to implement an online speech recognition system Introduction: With the continuous development of technology, speech recognition technology has become an important part of the field of artificial intelligence. The online speech recognition system based on WebSocket and JavaScript has the characteristics of low latency, real-time and cross-platform, and has become a widely used solution. This article will introduce how to use WebSocket and JavaScript to implement an online speech recognition system.

WebSocket and JavaScript: Key technologies for realizing real-time monitoring systems Introduction: With the rapid development of Internet technology, real-time monitoring systems have been widely used in various fields. One of the key technologies to achieve real-time monitoring is the combination of WebSocket and JavaScript. This article will introduce the application of WebSocket and JavaScript in real-time monitoring systems, give code examples, and explain their implementation principles in detail. 1. WebSocket technology

Introduction to how to use JavaScript and WebSocket to implement a real-time online ordering system: With the popularity of the Internet and the advancement of technology, more and more restaurants have begun to provide online ordering services. In order to implement a real-time online ordering system, we can use JavaScript and WebSocket technology. WebSocket is a full-duplex communication protocol based on the TCP protocol, which can realize real-time two-way communication between the client and the server. In the real-time online ordering system, when the user selects dishes and places an order

How to use WebSocket and JavaScript to implement an online reservation system. In today's digital era, more and more businesses and services need to provide online reservation functions. It is crucial to implement an efficient and real-time online reservation system. This article will introduce how to use WebSocket and JavaScript to implement an online reservation system, and provide specific code examples. 1. What is WebSocket? WebSocket is a full-duplex method on a single TCP connection.

JavaScript and WebSocket: Building an efficient real-time weather forecast system Introduction: Today, the accuracy of weather forecasts is of great significance to daily life and decision-making. As technology develops, we can provide more accurate and reliable weather forecasts by obtaining weather data in real time. In this article, we will learn how to use JavaScript and WebSocket technology to build an efficient real-time weather forecast system. This article will demonstrate the implementation process through specific code examples. We

JavaScript tutorial: How to get HTTP status code, specific code examples are required. Preface: In web development, data interaction with the server is often involved. When communicating with the server, we often need to obtain the returned HTTP status code to determine whether the operation is successful, and perform corresponding processing based on different status codes. This article will teach you how to use JavaScript to obtain HTTP status codes and provide some practical code examples. Using XMLHttpRequest

Usage: In JavaScript, the insertBefore() method is used to insert a new node in the DOM tree. This method requires two parameters: the new node to be inserted and the reference node (that is, the node where the new node will be inserted).

JavaScript is a programming language widely used in web development, while WebSocket is a network protocol used for real-time communication. Combining the powerful functions of the two, we can create an efficient real-time image processing system. This article will introduce how to implement this system using JavaScript and WebSocket, and provide specific code examples. First, we need to clarify the requirements and goals of the real-time image processing system. Suppose we have a camera device that can collect real-time image data
