簡體   English   中英

NodeJS中的JavaScript類和模塊

[英]JavaScript Classes and Modules in NodeJS

我很難理解如何將單獨的.js文件導入到index.js節點文件中。

我創建了一個文件pokemon.js,如下所示:

var pokemon = (function(){

  function Pokemon(name) {

    this.name = name; 
    console.log("pokemon");
  }

})();

module.exports.Pokemon = pokemon; 

現在在我的index.js中,我想使用它:

var Pokemon = require('./models/pokemon.js');

//如何調用Pokemon函數?

更新

var Pokemon = require('./models/models.js');
var app = express();

var pokemons = [];

app.get("/pokemon/all",function(req,res){

  var pokemon = Pokemon("Pikachu"); // Pokemon is not a function



})

這是我找到的解決方案:

models.js:

module.exports = function(name) {
  this.name = name; 
}

index.js: 

var Pokemon = require('./models/models.js');
var app = express();

var pokemons = [];

app.get("/pokemon/all",function(req,res){

  var pokemon = new Pokemon('Pikachu');
  pokemons.push(pokemon);
  res.json(pokemons);

})

我看到您要導出對象構造函數。

pokemon.js

function Pokemon(name){
   this.name = name;
   console.log(this.name);
}
// if any prototype
Pokemon.prototype.serviceOne = function(){ };
Pokemon.prototype.serviceTwo = function(){ };


module.exports = Pokemon;

index.js

var Pokemon = require('path/to/pokemon'); 
app.get("/pokemon/all",function(req,res){

    var pikachu= new Pokemon("Pikachu"); 
    pikachu.serviceOne();
    pikachu.serviceTwo();

})

@catta提供的只是有一個小錯誤嘗試:

var pokemon = function(name) {
this.name = name; 
console.log("pokemon");
}
module.exports.Pokemon = pokemon; 

在index.js中

var Pokemon = require('./models.js'); 
Pokemon.Pokemon('name') //output name

pokemon.js

var pokemon = function(str){
    this.name = str; 
    console.log(this.name);
};
module.exports.Pokemon = pokemon;

main.js

var Pokemon = require('./models/models.js');
var app = express();
var pokemons = [];
app.get("/pokemon/all",function(req,res){
  pokemons.push(Pokemon.Pokemon("Pikachu"));
})

當您將var key設置為要求時,僅引用該文件。 因此,您需要“ Pokemon.Pokemon()”

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM