最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

如何使用nodejs服务器读取HTML文件渲染至前端

来源:动视网 责编:小采 时间:2020-11-27 19:44:51
文档

如何使用nodejs服务器读取HTML文件渲染至前端

如何使用nodejs服务器读取HTML文件渲染至前端:这次给大家带来如何使用nodejs 服务器读取HTML文件渲染至前端,使用nodejs 服务器读取HTML文件渲染至前端的注意事项有哪些,下面就是实战案例,一起来看一下。1.分别简单实现三个备用页面。代码片段:<!DOCTYPE html> <html>
推荐度:
导读如何使用nodejs服务器读取HTML文件渲染至前端:这次给大家带来如何使用nodejs 服务器读取HTML文件渲染至前端,使用nodejs 服务器读取HTML文件渲染至前端的注意事项有哪些,下面就是实战案例,一起来看一下。1.分别简单实现三个备用页面。代码片段:<!DOCTYPE html> <html>
 这次给大家带来如何使用nodejs 服务器读取HTML文件渲染至前端,使用nodejs 服务器读取HTML文件渲染至前端的注意事项有哪些,下面就是实战案例,一起来看一下。

1.分别简单实现三个备用页面。

代码片段:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"> 
<title></title> 
<style>
.center {
 margin: auto;
 width: 60%;
 border: 3px solid #73AD21;
 padding: 10px;
}
</style>
</head>
<body>
<h2>元素居中对齐</h2>
<p>水平居中块级元素 (如 p), 可以使用 margin: auto;</p>
<p class="center">
 <p><b>注意: </b>使用 margin:auto 无法兼容 IE8, 除非 !DOCTYPE 已经声明。</p>
</p>
</body>
</html>

notFount.html页面

<!DOCTYPE HTML>
<html>
<head>
<script>
</script>
<style>
.center {
 margin: auto;
 width: 60%;
 border: 3px solid #73AD21;
 padding: 10px;
	color:red;
}
</style>
</head>
<body>
<p class ="center" >404 Not Fount</p>
</body>
</html>

2.修改创建的nodejs 服务器页面,对不同地址的请求做出不同的响应页面。

在url地址判断中添加,文件读取代码,以实现读取定义的html页面。

声明文件系统对象:

// 声明文件操作系统对象 
 var fs = require('fs');

实现文件内容读取并渲染到页面

if(url ==='/'){ 
 //response.writeHead(响应状态码,响应头对象): 发送一个响应头给请求。 
 response.writeHead(200,{'Content-Type':'text/html'}) 
 // 如果url=‘/' ,读取指定文件下的html文件,渲染到页面。 
 fs.readFile('./practice/login.html','utf-8',function(err,data){ 
 if(err){ 
 throw err ; 
 } 
 response.end(data); 
 }); 
}

完整代码:

	/**
	
	1.使用 HTTP 服务器与客户端交互,需要 require('http')。
	声明http协议
	*/
	var http = require('http');
	
	
	// 声明文件操作系统对象
	var fs = require('fs');
	/**
	2.获取服务器对象
	1.通过 http.createServer([requestListener]) 创建一个服务
	requestListener <Function>
	返回: <http.Server>
	返回一个新建的 http.Server 实例。
	对于服务端来说,主要做三件事:
	1.接受客户端发出的请求。
	2.处理客户端发来的请求。
	3.向客户端发送响应。
	*/
	
	var server = http.createServer();
	/**
	3.声明端口号,开启服务。
	server.listen([port][, host][, backlog][, callback])
	port <number> :端口号
	host <string> :主机ip
	backlog <number> server.listen() 函数的通用参数
	callback <Function> server.listen() 函数的通用参数
	Returns: <net.Server>
	启动一个TCP服务监听输入的port和host。
	如果port省略或是0,系统会随意分配一个在'listening'事件触发后能被server.address().port检索的无用端口。
	如果host省略,如果IPv6可用,服务器将会接收基于unspecified IPv6 address (::)的连接,否则接收基于unspecified IPv4 address (0.0.0.0)的连接
	
	*/
	server.listen(9001, function(){
	 console.log('服务器正在端口号:9001上运行......');
	})
	
	
	/**
	4.给server 实例对象添加request请求事件,该请求事件是所有请求的入口。
	任何请求都会触发改事件,然后执行事件对应的处理函数。
	
	server.on('request',function(){
	 console.log('收到客户端发出的请求.......');
	});
	*/
	
	/**
	5.设置请求处理函数。
	请求回调处理函数需要接收两个参数。
	request :request是一个请求对象,可以拿到当前浏览器请求的一些信息。
	eg:请求路径,请求方法等
	response: response是一个响应对象,可以用来给请求发送响应。
	
	*/
	server.on('request',function(request,response){
	
	var url = request.url;
	if(url ==='/'){
	//response.writeHead(响应状态码,响应头对象): 发送一个响应头给请求。
	response.writeHead(200,{'Content-Type':'text/html'})
	// 如果url=‘/' ,读取指定文件下的html文件,渲染到页面。
	fs.readFile('./practice/login.html','utf-8',function(err,data){
	if(err){
	throw err ;
	}
	response.end(data);
	});
	
	}else if(url === '/login'){
	response.writeHead(200,{'Content-Type':'text/html'});
	// 如果url=‘/' ,读取指定文件下的html文件,渲染到页面。
	fs.readFile('./practice/login.html','utf-8',function(err,data){
	if(err){
	throw err ;
	}
	response.end(data);
	});
	}else if(url === '/index'){
	response.writeHead(200,{'Content-Type':'text/html'});
	// 如果url=‘/' ,读取指定文件下的html文件,渲染到页面。
	fs.readFile('./practice/index.html','utf-8',function(err,data){
	if(err){
	throw err ;
	}
	response.end(data);
	});
	}else{
	response.writeHead(200,{'Content-Type':'text/html'});
	// 如果url=‘/' ,读取指定文件下的html文件,渲染到页面。
	fs.readFile('./practice/notFount.html','utf-8',function(err,data){
	if(err){
	throw err ;
	}
	response.end(data);
	});
	}
	
	});	
	

最终实现效果:

开启nodejs服务器,在地址栏中输入:127.0.0.0.1:9001或127.0.0.0.1:9001/login

在地址栏中输入:127.0.0.0.1:9001/index

在地址栏中输入:127.0.0.0.1:9001/其他内容

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

应该如何搭建webpack+react开发环境

如何搭建React全家桶环境

文档

如何使用nodejs服务器读取HTML文件渲染至前端

如何使用nodejs服务器读取HTML文件渲染至前端:这次给大家带来如何使用nodejs 服务器读取HTML文件渲染至前端,使用nodejs 服务器读取HTML文件渲染至前端的注意事项有哪些,下面就是实战案例,一起来看一下。1.分别简单实现三个备用页面。代码片段:<!DOCTYPE html> <html>
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top