您的位置:首页 > Web前端 > Node.js

Node.js将项目部署在静态服务器中,与自定义模块的创建和发布。

2019-05-15 11:20 531 查看

Node.js创建一个静态服务器,然后将项目部署在这个服务器中

源代码:

var http = require( 'http' );

var port = 8080 ;

var hostname = '127.0.0.1'

var path = require( 'path' )  // 磁盘路径处理的模块

var fs = require( 'fs' ) // 操作文件、目录的模块

var url = require( 'url' ) // 处理url

var server = http.createServer( function ( request, response ) {

var staticPath = path.join( __dirname,'static'  )

var urlObj = url.parse( request.url )

if( urlObj.pathname === '/'){
urlObj.pathname += 'index.html'
}

console.log( urlObj.pathname )

// fs.readFile(路径,字符编码,错误优先的回调函数)

var filePath = path.join( staticPath, urlObj.pathname )

fs.readFile( filePath,'binary',function( error,filecontent ) {
if ( error ){
throw error
}else {
response.write( filecontent, 'binary' )
response.end()
}
})
})

server.listen( port , hostname , function () {

console.log( `The server is runing: http://${ hostname }:${ port }` )

})

将项目一个页面部署在Node.js的静态服务器上

模块/包 与Common.js

Node.js使用了Common.js规范

Node.js中Common.js规范有三种使用类型:

  1. 内置模块 path url fs precess

  2. 第三方模块:插件

  3. 自定义模块
    3.1.先定义一个变量,变量值可以随意
    3.2. 导出模块

    module.exports = 变量名
    
    module.exports = {
    变量名
    }

    3.3. 导入
    如果是第一种方式导出 ,var 变量名 = require( 相对路径 )
    如果是第二种方式导出,var { 变量名 } = require ( 相对路径 )

    源代码:

var {name} = require( './name.js' );

var student = {
id: 1,
name: '老彭'
}

module.exports = {
student,
name
}

前端模块化

  1. AMD ( require.js )
  2. CMD ( sea.js )
  3. Common.js ( module.export require )
  4. es6 模块化 ( export import )

自定义模块上传 npmjs.com 过程

  1. 创建package.json

  2. http://npmjs.com 上注册账号

  3. 激活账号( npmjs.com会发送一个邮件给你的注册邮箱 )

  4. 使用命令登录npmjs.com ( 登录前将你的源从淘宝源 切到 npmjs)

      问题 : 如何切换源呢?
    • 解决: 使用 nrm 切换
    • nrm 安装
      $ npm i nrm -g

      $ npm adduser
  5. 如果登录成功, 提示为: Logged in as ***** on https://registry.npmjs.org/.

  6. 发布包到npmjs

    $ npm publish

  7. 在npmjs官网查看包有没有发送上去

  8. 下载包来使用一下

    $ npm i 包名称 -S / -D

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: