您好,登錄后才能下訂單哦!
本篇內(nèi)容介紹了“如何用Node.js進(jìn)行html頁面跳轉(zhuǎn)”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
最近在使用Node.js和html學(xué)習(xí)頁面的相關(guān)知識,在學(xué)習(xí)到頁面跳轉(zhuǎn)時,出現(xiàn)了跳轉(zhuǎn)不成功的問題,在這里記錄下,供以后參考。
在Node.js中,主要使用express框架,前端則使用html。
該小Demo主要涉及四個文件,包括:
main.js:該部分為起始文件,是整個項目的入口文件;
main.html:該部分是主頁面的html文件;
new.html:要跳轉(zhuǎn)頁面的html文件;
router.js:路由文件,用來根據(jù)URL及參數(shù)給出具體的操作;
node_modules:存放相關(guān)模塊的文件夾。
注:main.html和new.html兩個在views文件夾下。
使用npm分別install以下三個模塊:
express
art-template
express-art-template
代碼
部分如下:
const express = require('express') const app = express() const router = require('./router') app.engine('html',require('express-art-template')) app.use(router) app.listen(3000,() => { console.log('successful...') })
實現(xiàn)了對3000端口的監(jiān)聽。
在該文件中,主要創(chuàng)建路由實例,對URL及相關(guān)參數(shù)實現(xiàn)監(jiān)聽,并渲染相關(guān)界面。
代碼
部分如下:
const express = require('express') //創(chuàng)建路由實例 const router = express.Router() router.get('/',(req,res) => { res.render('main.html') }) module.exports = router //暴露接口
在該文件下,只實現(xiàn)了一個超鏈接,用來實現(xiàn)實現(xiàn)頁面的跳轉(zhuǎn),代碼
部分如下:
<div> <a href="/new" >頁面跳轉(zhuǎn)</a> <!--跳轉(zhuǎn)至新頁--> </div>
本文件十分簡單,只是用一行輸出語句來表示跳轉(zhuǎn)成功,代碼
部分如下:
<div> <th>成功實現(xiàn)跳轉(zhuǎn)</th> </div>
在小黑屏中輸入命令
:
node main.js
代碼成功運行,打開http://localhost:3000
:
可以看到出現(xiàn)了跳轉(zhuǎn)頁面的超鏈接,點擊這個超鏈接:
頁面并沒有實現(xiàn)有效的跳轉(zhuǎn)。
如果純粹使用html語言,是可以直接實現(xiàn)超鏈接的跳轉(zhuǎn)的,在使用router后,應(yīng)該實現(xiàn)對相關(guān)URL的監(jiān)聽才可以實現(xiàn)跳轉(zhuǎn)的目標(biāo)。
于是,在router.js中補充如下的代碼
:
router.get('/new',function(req,res){ res.render('new.html') })
即當(dāng)URL為localhost:3000/new
時,使用res.render跳轉(zhuǎn)。
由于html的超鏈接與render渲染的鏈接保持一致,因此可以實現(xiàn)使用超鏈接的跳轉(zhuǎn)。
跳轉(zhuǎn)的效果如下:
“如何用Node.js進(jìn)行html頁面跳轉(zhuǎn)”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。