通過(guò)nodejs 服務(wù)器讀取HTML文件渲染到頁(yè)面的方法
1.分別簡(jiǎn)單實(shí)現(xiàn)三個(gè)備用頁(yè)面。
login.html頁(yè)面
index.html頁(yè)面
代碼片段:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鳥教程(runoob.com)</title>
<style>
.center {
margin: auto;
width: 60%;
border: 3px solid #73AD21;
padding: 10px;
}
</style>
</head>
<body>
<h2>元素居中對(duì)齊</h2>
<p>水平居中塊級(jí)元素 (如 div), 可以使用 margin: auto;</p>
<div class="center">
<p><b>注意: </b>使用 margin:auto 無(wú)法兼容 IE8, 除非 !DOCTYPE 已經(jīng)聲明。</p>
</div>
</body>
</html>
notFount.html頁(yè)面
<!DOCTYPE HTML>
<html>
<head>
<script>
</script>
<style>
.center {
margin: auto;
width: 60%;
border: 3px solid #73AD21;
padding: 10px;
color:red;
}
</style>
</head>
<body>
<div class ="center" >404 Not Fount</div>
</body>
</html>
2.修改創(chuàng)建的nodejs 服務(wù)器頁(yè)面,對(duì)不同地址的請(qǐng)求做出不同的響應(yīng)頁(yè)面。
在url地址判斷中添加,文件讀取代碼,以實(shí)現(xiàn)讀取定義的html頁(yè)面。
聲明文件系統(tǒng)對(duì)象:
// 聲明文件操作系統(tǒng)對(duì)象
var fs = require('fs');
實(shí)現(xiàn)文件內(nèi)容讀取并渲染到頁(yè)面
if(url ==='/'){
//response.writeHead(響應(yīng)狀態(tài)碼,響應(yīng)頭對(duì)象): 發(fā)送一個(gè)響應(yīng)頭給請(qǐng)求。
response.writeHead(200,{'Content-Type':'text/html'})
// 如果url=‘/' ,讀取指定文件下的html文件,渲染到頁(yè)面。
fs.readFile('./practice/login.html','utf-8',function(err,data){
if(err){
throw err ;
}
response.end(data);
});
}
完整代碼:
/**
1.使用 HTTP 服務(wù)器與客戶端交互,需要 require('http')。
聲明http協(xié)議
*/
var http = require('http');
// 聲明文件操作系統(tǒng)對(duì)象
var fs = require('fs');
/**
2.獲取服務(wù)器對(duì)象
1.通過(guò) http.createServer([requestListener]) 創(chuàng)建一個(gè)服務(wù)
requestListener <Function>
返回: <http.Server>
返回一個(gè)新建的 http.Server 實(shí)例。
對(duì)于服務(wù)端來(lái)說(shuō),主要做三件事:
1.接受客戶端發(fā)出的請(qǐng)求。
2.處理客戶端發(fā)來(lái)的請(qǐng)求。
3.向客戶端發(fā)送響應(yīng)。
*/
var server = http.createServer();
/**
3.聲明端口號(hào),開啟服務(wù)。
server.listen([port][, host][, backlog][, callback])
port <number> :端口號(hào)
host <string> :主機(jī)ip
backlog <number> server.listen() 函數(shù)的通用參數(shù)
callback <Function> server.listen() 函數(shù)的通用參數(shù)
Returns: <net.Server>
啟動(dòng)一個(gè)TCP服務(wù)監(jiān)聽輸入的port和host。
如果port省略或是0,系統(tǒng)會(huì)隨意分配一個(gè)在'listening'事件觸發(fā)后能被server.address().port檢索的無(wú)用端口。
如果host省略,如果IPv6可用,服務(wù)器將會(huì)接收基于unspecified IPv6 address (::)的連接,否則接收基于unspecified IPv4 address (0.0.0.0)的連接
*/
server.listen(9001, function(){
console.log('服務(wù)器正在端口號(hào):9001上運(yùn)行......');
})
/**
4.給server 實(shí)例對(duì)象添加request請(qǐng)求事件,該請(qǐng)求事件是所有請(qǐng)求的入口。
任何請(qǐng)求都會(huì)觸發(fā)改事件,然后執(zhí)行事件對(duì)應(yīng)的處理函數(shù)。
server.on('request',function(){
console.log('收到客戶端發(fā)出的請(qǐng)求.......');
});
*/
/**
5.設(shè)置請(qǐng)求處理函數(shù)。
請(qǐng)求回調(diào)處理函數(shù)需要接收兩個(gè)參數(shù)。
request :request是一個(gè)請(qǐng)求對(duì)象,可以拿到當(dāng)前瀏覽器請(qǐng)求的一些信息。
eg:請(qǐng)求路徑,請(qǐng)求方法等
response: response是一個(gè)響應(yīng)對(duì)象,可以用來(lái)給請(qǐng)求發(fā)送響應(yīng)。
*/
server.on('request',function(request,response){
var url = request.url;
if(url ==='/'){
//response.writeHead(響應(yīng)狀態(tài)碼,響應(yīng)頭對(duì)象): 發(fā)送一個(gè)響應(yīng)頭給請(qǐng)求。
response.writeHead(200,{'Content-Type':'text/html'})
// 如果url=‘/' ,讀取指定文件下的html文件,渲染到頁(yè)面。
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文件,渲染到頁(yè)面。
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文件,渲染到頁(yè)面。
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文件,渲染到頁(yè)面。
fs.readFile('./practice/notFount.html','utf-8',function(err,data){
if(err){
throw err ;
}
response.end(data);
});
}
});
最終實(shí)現(xiàn)效果:
開啟nodejs服務(wù)器,在地址欄中輸入: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/其他內(nèi)容

以上這篇通過(guò)nodejs 服務(wù)器讀取HTML文件渲染到頁(yè)面的方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- javascript頁(yè)面渲染速度測(cè)試腳本分享
- 快速解決js動(dòng)態(tài)改變dom元素屬性后頁(yè)面及時(shí)渲染的問(wèn)題
- vue.js,ajax渲染頁(yè)面的實(shí)例
- ajax請(qǐng)求+vue.js渲染+頁(yè)面加載的示例
- Vue.js 通過(guò)jQuery ajax獲取數(shù)據(jù)實(shí)現(xiàn)更新后重新渲染頁(yè)面的方法
- php使用QueryList輕松采集js動(dòng)態(tài)渲染頁(yè)面方法
- 詳解Next.js頁(yè)面渲染的優(yōu)化方案
- JS利用?React.lazy?優(yōu)化頁(yè)面初次渲染
相關(guān)文章
node.js+postman實(shí)現(xiàn)模擬HTTP服務(wù)器與客戶端交互
本文主要介紹了node.js+postman實(shí)現(xiàn)模擬HTTP服務(wù)器與客戶端交互,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07
node.js中使用q.js實(shí)現(xiàn)api的promise化
這篇文章主要介紹了node.js中使用q.js實(shí)現(xiàn)api的promise化,promise一個(gè)標(biāo)準(zhǔn),它描述了異步調(diào)用的返回結(jié)果,包括正確返回結(jié)果和錯(cuò)誤處理,需要的朋友可以參考下2014-09-09
使用node.js 制作網(wǎng)站前臺(tái)后臺(tái)
本文給大家介紹實(shí)用node.js 制作網(wǎng)站前臺(tái)和后臺(tái),非常的詳盡,有需要的朋友可以參考下2014-11-11
詳解如何在nodejs項(xiàng)目中使用Vue的響應(yīng)式API
vue3的響應(yīng)式API大家應(yīng)該都特別熟悉,平時(shí)大家都是在vue-cli或者vite創(chuàng)建的vue項(xiàng)目里面使用的這些響應(yīng)式API,今天小編來(lái)和大家聊聊如何在node.js項(xiàng)目中使用vue的響應(yīng)式API吧2024-11-11
nodejs實(shí)現(xiàn)郵件發(fā)送服務(wù)實(shí)例分享
本文給大家講解的是簡(jiǎn)單的使用nodejs搭建郵件發(fā)送服務(wù)的一個(gè)實(shí)例,非常的好用,有需要的小伙伴可以參考下2017-03-03
nodejs利用ajax實(shí)現(xiàn)網(wǎng)頁(yè)無(wú)刷新上傳圖片實(shí)例代碼
本篇文章主要介紹了nodejs利用ajax實(shí)現(xiàn)網(wǎng)頁(yè)無(wú)刷新上傳圖片實(shí)例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06

