将公共的功能抽离成为单独的js文件作为一个模块,默认情况下面把这个模块里面的方法或属性,外面是没法访问的。必须在模块里面通过exports或者module.exports暴露属性或者方法
// tool.js文件
function formatApi(api){
return "http://www.itying.com"+api
}
exports.formatApi = formatApi;
const { Console } = require('console');
var http = require('http');
// 导入公共文件tools.js
const tools = require('./module/tools.js')
console.log(tools)
http.createServer(function (request, response) {
response.writeHead(200, {'Content-Type': 'text/plain'});
// var api = formatApi('api/plist')
var api = tools.formatApi('api/focus')
response.write(api)
response.end();
}).listen(3000);
console.log('Server running at http://127.0.0.1:3000/');
设置公共common.js模块化
通过创建自定义函数并导出
//axios文件下的index.js
var obj = {
get:function(){
console.log('从服务器获取数据')
},
post:function(){
console.log('提交数据')
}
}
// exports.obj = obj;
module.exports = obj;
// exports.get = function(){
// console.log('从服务器获取数据')
// }
// exports.post = function(){
// console.log('提交数据')
// }
const axios = require('./node_modules/axios/index')
axios.get()//从服务器获取数据
axios.post()//提交数据
//db文件下的db.js
var obj = {
find:function(){
console.log('查找数据')
},
add:function(){
console.log('增加数据')
}
}
module.exports = obj;
在公共部分的文件路径打开CMD命令使用npm init --yes 生成一个pakeage.json文件,这个文件主要是用来记录这个项目的详细信息的,它会将我们在项目开发中所要用到的包,以及项目的详细信息等记录在这个项目中。方便在以后的版本迭代和项目移植的时候会更加的方便。也是防止在后期的项目维护中误删除了一个包导致的项目不能够正常运行。使用npm init初始化项目还有一个好处就是在进行项目传递的时候不需要将项目依赖包一起发送给对方,对方在接受到你的项目之后再执行npm install就可以将项目依赖全部下载到项目里。话不多说我们就直接开始进行操作。
生成pakeage.json,引入功能时,只需要引入到文件路径上。
//commonjs05.js
var db = require('db') //错误 nodejs会默认查找node_modules对应模块的index.js
db.add();