請教:ajax提交數據為什么傳不到控制器呢?
問題描述
我在學習Peter.zhu老師的《最新ThinkPHP 5.1全球首發視頻教程(60天成就PHP大牛線上**班課)》的時
候,其中第“10-3用戶注冊功能的初步實現”節,為什么我的ajax提交數據不能傳到控制器呢?
register.html代碼為:
{include file="public:header" /}
{include file="public:nav" /}
<div class="row">
<div class="col-md-8">
<div class="page-header">
<h2>用戶注冊</h2>
</div>
<form class="form-horizontal" method="post" id="login" >
<div class="form-group">
<label for="inputEmail1" class="col-sm-2 control-label">用戶名:</label>
<div class="col-sm-10">
<input type="text" name="name" class="form-control" id="inputEmail1"
placeholder="UserName">
</div>
</div>
<div class="form-group">
<label for="inputEmail2" class="col-sm-2 control-label">郵箱:</label>
<div class="col-sm-10">
<input type="text" name="email" class="form-control" id="inputEmail2"
placeholder="Email">
</div>
</div>
<div class="form-group">
<label for="inputEmail3" class="col-sm-2 control-label">手機號:</label>
<div class="col-sm-10">
<input type="text" name="mobile" class="form-control" id="inputEmail3"
placeholder="MobileNumber">
</div>
</div>
<div class="form-group">
<label for="inputEmail4" class="col-sm-2 control-label">密碼:</label>
<div class="col-sm-10">
<input type="password" name="password" class="form-control" id="inputEmail4"
placeholder="Password">
</div>
</div>
<div class="form-group">
<label for="inputEmail5" class="col-sm-2 control-label">確認密碼:</label>
<div class="col-sm-10">
<input type="password" name="password_confirm" class="form-control" id="inputEmail5"
placeholder="Password Confrim">
</div>
</div>
<div class="form-group">
<div class="col-sm-offset-2 col-sm-10">
<button type="submit" class="btn btn-primary" id="register">注冊</button>
</div>
</div>
</form>
</div>
<script type="text/javascript">
$(function(){
$('#register').on('click',function(){
//用ajax提交用戶信息
$.ajax({
type: 'post',
url: "{:url('insert')}",
data: $('#login').serialize(),
dataType: 'json',
success: function(data){
switch (data.status)
{
case 1:
alert(data.message);
window.location.href = "{:url('index/index')}";
break;
case 0:
case -1:
alert(data.message);
window.location.back();
break;
}
}
})
})
})
</script>
{include file="public:right" /}
{include file="public:footer" /}
控制器index/User的代碼為:
<?php
namespace appindexcontroller;
use appcommoncontrollerBase;
use thinkfacadeRequest;
use appcommonmodelUser as UserModel;
class User extends Base
{
// 注冊頁面
public function register()
{
$this->assign('title','用戶注冊');
return $this->fetch();
}
public function index()
{
echo 'dfdssfsdf';
}
//處理用戶提交的用戶信息
public function insert()
{
echo "<script type='text/javascript'>alert('insert被執行');</script>";
// echo "dfsdfsdf";
if(Request::isAjax()){
// 驗證數據
// $this->error("請求類型錯誤",'register');
$data = Request::post();//得到要驗證的數據
$rule = 'appcommonvalidateUser';//自定義的驗證規則
//開始驗證
$res=$this->validate($data,$rule);
if (true!==$res){//false
return ['status'=> -1,'message'=>$res];
}else {
if(UserModel::create($data))
{
return ['status'=>1,'message'=>'恭喜,注冊成功'];
}
else
{
return ['status'=>0,'message'=>'注冊失敗,請檢查'];
}
}//true
// 使用模型來創建數據
// 獲取用戶通過表單提交過來的數據
// $data=Request::except('password_confirm','post');
// $this->success($data,'index/index/index');
}
else
{
$this->error("請求類型錯誤",'index');
}
}
}
現象為在注冊頁面點擊“注冊”按鈕后,頁面刷新后仍為注冊頁面,沒有任何錯誤提示,這是為什么呢
,一個星期也沒找到問題,謝謝各位老師解答!!!
問題解答
回答1:data為什么是login不應該是form表單嗎
回答2:好長相關文章:
1. Docker for Mac 創建的dnsmasq容器連不上/不工作的問題2. docker安裝后出現Cannot connect to the Docker daemon.3. css - 定位為absolute的父元素中的子元素 如何設置在父元素的下面?4. javascript - angualr2中emit觸發一個方法然后怎么獲得這個promise的結果5. java - 請問在main方法中寫成對象名.屬性()并賦值,與直接參參數賦值輸錯誤是什么原因?6. mysql里的大表用mycat做水平拆分,是不是要先手動分好,再配置mycat7. java - Spring boot 讀取 放在 jar 包外的,log4j 配置文件,系統有創建日志文件,不寫入日志信息。8. javascript - 圖片鏈接請求一直是pending狀態,導致頁面崩潰,怎么解決?9. python - beautifulsoup獲取網頁內容的問題10. 怎么用css截取字符?
