亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術文章
文章詳情頁

html5 - 通過post抓取的頁面數據 為啥不能展現在頁面上

瀏覽:144日期:2023-10-09 17:41:01

問題描述

這是node.js代碼

var http = require('http'), fs = require('fs'), querystring = require('querystring'), url = require('url');http.createServer(function(req,res){ var postdata=''; var query='what'; var pathname = url.parse(req.url).pathname; req.setEncoding('utf8'); if(pathname=='/'){var indexPage = fs.readFileSync('表單.html');res.writeHead(200,{'Content-Type':'text/html'});res.end(indexPage); } if(pathname=='/about'){req.on('data',function(chunk){ postdata += chunk;});req.on('end',function() { console.log(postdata); query = querystring.parse(postdata); console.log(query);});res.writeHead(200, {'Content-Type':'text/plain'});console.log(query.Name);console.log(query.number);res.write(query.number+ 'and '+query.number);res.end(); } else{res.writeHead(404,{'Content-Type':'text/plain'});res.end('Can not find the source'); }}).listen(2000,'127.0.0.1');console.log('The server is running at port 2000');這是html代碼<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>表單填寫</title></head><body><form action='/about' method='post'> <p> Name: <input type='text' name='Name'></p> <p>SchoolNumber:<input type='text' name='number'></p> <p><input type='submit' value='提交'></p></form></body></html>執行結果圖:

html5 - 通過post抓取的頁面數據 為啥不能展現在頁面上

html5 - 通過post抓取的頁面數據 為啥不能展現在頁面上

求大神解決 小弟感激不盡

問題解答

回答1:

原因分析:回調函數執行順序的問題, 加點打印信息看看html5 - 通過post抓取的頁面數據 為啥不能展現在頁面上

res.write()那一行返回的是你最開始定義的query并沒有執行req.on()里面的操作,而這時的query還是你定義的字符串'what',它不是一個json對象,所以就沒有number屬性,所以是undefined。解決方案:你可以把res.write()寫在req.on()里面,像這樣:html5 - 通過post抓取的頁面數據 為啥不能展現在頁面上

回答2:

怎么沒見你判斷請求方法啊?這個是我之前寫的一個示例,你可以參考一下:

var http=require(’http’);var url=require(’url’);var fs=require(’fs’);var querystring=require(’querystring’);var mgd=require(’./mongodb.js’);http.createServer(function(req,res){ switch(req.method){case ’POST’: update(req,res); break;case ’GET’: get(req,res); break;default:break; }}).listen(8080);function update(req,res){ var pathname=url.parse(req.url).pathname; var postData=’’; /*接收評論*/ if(pathname==’/postComment’){req.addListener(’data’,function(data){ postData+=data;});req.addListener(’end’,function(){ var json=querystring.parse(postData); mgd(function(c){c.insert(’comment’,json,function(){ var json={} json.code=1; res.writeHead(’Content-Type:application/json;charset=UTF-8’); res.write(JSON.stringify(json)); res.end();}); });}) }}function get(req,res){ var pathname=url.parse(req.url).pathname;/*主頁*/ if(pathname===’/’){fs.readFile(’test.html’,function(err,file){ res.end(file);}) } /*獲取評論列表*/ if(pathname==’/comment’){mgd(function(c){ c.find(’comment’,{},function(data){var json={};if(data.length!=0){ json.code=1; json.data=data;}else{ json.code=0; json.data=null;}json=JSON.stringify(json)res.writeHead(’Content-Type:application/json;charset=UTF-8’);res.write(json);res.end(); }) }) }}

mongodb.js的代碼需要的話可以在我的github上看一波,其實就是一個簡單的評論demo

標簽: Html5
相關文章:
主站蜘蛛池模板: 国产一区二区三区视频在线观看 | 国产精品久久久久久久免费 | 日韩手机看片福利精品 | 91精选视频 | 国产在线不卡视频 | 怡红院免费全部视频在线 | 极品美女写真菠萝蜜视频 | 男女福利| 99在线看| 免费一级a毛片在线 | 欧美国产日韩在线播放 | yy6080久久亚洲精品 | 亚洲产国偷v产偷v自拍涩爱 | 中国农村一级毛片 | 国产深夜福利视频在线播放 | 香港一级特黄高清免费 | 免费一区二区三区四区五区 | 五月色婷婷综合开心网4438 | 久久久久9999 | 国产精品欧美亚洲 | 老头做爰xxxx视频 | 寂寞午夜影院 | 玖玖精品在线观看 | 国产的一级毛片完整 | 久久依人| 草久视频在线 | 97精品国产综合久久久久久欧美 | 国产三级日产三级日本三级 | 九九免费精品视频在这里 | 久久综合成人网 | 欧美在线观看高清一二三区 | 羞羞一区二区三区四区片 | 日韩在线视精品在亚洲 | 一本色道久久88加勒比—综合 | 在线观看日本视频免费 | a成人在线 | 亚洲成a人片在线观看中文 亚洲成a人片在线观看中文!!! | 高清毛片aaaaaaaaa片 | 国产或人精品日本亚洲77美色 | 久久99亚洲精品一区二区 | avove在线播放|