開(kāi)始寫(xiě)的時(shí)候AJAX還提交過(guò)去了,到后面不知道寫(xiě)到什么了,就突然沒(méi)反應(yīng)了。
代碼可能有點(diǎn)多,但是都有注釋,思路也很簡(jiǎn)單,我把重點(diǎn)代碼截圖出來(lái),希望大佬們幫忙看一看??!
現(xiàn)在的問(wèn)題是:
點(diǎn)擊這個(gè)注冊(cè),network顯示并沒(méi)有發(fā)出AJAX請(qǐng)求。
登陸regist.ejs:
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<!-- 上述3個(gè)meta標(biāo)簽*必須*放在最前面,任何其他內(nèi)容都*必須*跟隨其后! -->
<meta name="description" content="">
<meta name="author" content="">
<link rel="icon" href="../../favicon.ico">
<title>Jumbotron Template for Bootstrap</title>
<!-- Bootstrap core CSS -->
<link rel="stylesheet">
<!-- Custom styles for this template -->
<link href="jumbotron.css" rel="stylesheet">
<style type = "text/css">
body {
padding-top: 100px;
}
#warning {
display: none;
}
</style>
<!-- HTML5 shim and Respond.js for IE8 support of HTML5 elements and media queries -->
<!--[if lt IE 9]>
<script src="https://cdn.bootcss.com/html5shiv/3.7.3/html5shiv.min.js"></script>
<script src="https://cdn.bootcss.com/respond.js/1.4.2/respond.min.js"></script>
<![endif]-->
</head>
<body>
<nav class="navbar navbar-inverse navbar-fixed-top">
<div class="container">
<div class="navbar-header">
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false" aria-controls="navbar">
<span class="sr-only">Toggle navigation</span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<a class="navbar-brand" href="#">班級(jí)說(shuō)說(shuō)</a>
</div>
<div id="navbar" class="navbar-collapse collapse">
<ul class="nav navbar-nav">
<li class="active"><a href="#">全部說(shuō)說(shuō) <span class="sr-only">(current)</span></a></li>
<li><a href="#">我的說(shuō)說(shuō)</a></li>
</ul>
<ul class="nav navbar-nav navbar-right">
<li><a href="#">注冊(cè)</a></li>
<li><a href="#">登陸</a></li>
</ul>
</div><!--/.navbar-collapse -->
</div>
</nav>
<div class="container">
<!-- Example row of columns -->
<div class="row">
<h1>歡迎注冊(cè)</h1>
<form>
<div class="form-group">
<label for="username">用戶名</label>
<input type="text" class="form-control" id="username" placeholder="可以是中文,不能和別人重復(fù)">
</div>
<div class="form-group">
<label for="exampleInputPassword1">密碼</label>
<input type="password" class="form-control" id="password" placeholder="至少六位">
</div>
<div class="form-group">
<label for="exampleInputFile">File input</label>
<input type="file" id="exampleInputFile">
<p class="help-block">Example block-level help text here.</p>
</div>
<div class="checkbox">
<label>
<input type="checkbox"> 我遵守注冊(cè)規(guī)定
</label>
</div>
<button type="submit" class="btn btn-default" id = "signup">注冊(cè)</button>
</form>
<div class="alert alert-danger" role="alert" id ="warning">
用戶名被占用,請(qǐng)更換
</div>
</div>
<hr>
<footer>
<p>© 2016 Company, Inc.</p>
</footer>
</div> <!-- /container -->
<!-- Bootstrap core JavaScript
================================================== -->
<!-- Placed at the end of the document so the pages load faster -->
<script src="https://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
<script src="https://cdn.bootcss.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
<script type="text/javascript">
// $("input").focus(function(){
// $("#cuowukuang").fadeOut();
// });
$("#signup").click(function(){
//注冊(cè)按鈕的事件,用ajax提交表單
$.post("/doregist",{
"username" : $("#username").val(),
"password" : $("#password").val()
},function(result){
console.log("AJAX成功");
if(result == "1"){
//注冊(cè)成功
alert("注冊(cè)成功!將自動(dòng)跳轉(zhuǎn)到首頁(yè)");
window.location = "/";
}else if(result == "-1"){
//用戶名被占用
$("#warning").fadeIn();
$("#warning").html("用戶名被占用??!");
}else if(result == "-3"){
//服務(wù)器錯(cuò)誤
}
});
});
</script>
</body>
</html>
這里是沒(méi)有打印出來(lái)的,所以這段代碼都沒(méi)有執(zhí)行??!
處理表單請(qǐng)求的:router.js:
var formidable = require("formidable");
var db = require("../models/db.js");
var md5 = require("../models/md5.js");
//顯示主頁(yè)
exports.showIndex = function (req,res,next) {
res.render("index",{
"login" : req.session.login == "1" ? true : false,
"username" : req.session.login == "1" ? req.session.username : ""
});
};
//注冊(cè)頁(yè)面
exports.showRegist = function (req,res,next) {
res.render("regist");
};
exports.showdoRegist = function (req,res,next) {
//得到用戶填寫(xiě)的東西
var form = new formidable.IncomingForm();
form.parse(req, function(err, fields, files) {
//得到表單之后做的事情
var username = fields.username;
var password = fields.password;
console.log(username + " " + password);
//查詢數(shù)據(jù)庫(kù)中是不是有這個(gè)人
db.find("users",{"username":username},function (err,result) {
if(err) {
//服務(wù)器錯(cuò)誤
res.send("-3");
return ;
}
if(result.length != 0) {
res.send("-1"); //被占用
return;
}
// console.log(result.length);
//設(shè)置md5加密
password = md5(password) + "lawliet";
//現(xiàn)在可以證明,用戶名沒(méi)有被占用
db.insertOne("users",{
"username" : username,
"password" : password
},function (err,result) {
console.log(result);
if(err) {
res.send("-3"); //服務(wù)器錯(cuò)誤
console.log("錯(cuò)誤");
return;
}
req.session.login = "1";
req.session.username = username;
res.send("1");//注冊(cè)成功,寫(xiě)入session
})
});
//保存這個(gè)人
});
}
數(shù)據(jù)庫(kù)是插入成功的
入口代碼:
var express = require("express");
var app = express();
var router = require("./router/router.js");
var session = require("express-session");
//模版引擎
app.set("view engine","ejs");
// 使用session
app.use(session({
secret: 'keyboard cat',
resave: false,
saveUninitialized: true,
cookie: { secure: true }
}))
//靜態(tài)頁(yè)面
app.use(express.static("./public"));
//路由表
app.get("/",router.showIndex);
app.get("/regist",router.showRegist);
app.post("/doregist",router.showdoRegist);
app.listen(3000);北大青鳥(niǎo)APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國(guó)家
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
北大課工場(chǎng)是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國(guó)家深化產(chǎn)教融合/校企合作的政策,積極推進(jìn)“中國(guó)制造2025”,實(shí)現(xiàn)中華民族偉大復(fù)興的升級(jí)產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國(guó)職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔(dān)任系統(tǒng)開(kāi)發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_(kāi)發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫(kù),具有快速界面開(kāi)發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁(yè)制作和網(wǎng)頁(yè)游戲開(kāi)發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開(kāi)發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問(wèn),美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。