請教: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');
}
}
}
現象為在注冊頁面點擊“注冊”按鈕后,頁面刷新后仍為注冊頁面,沒有任何錯誤提示,這是為什么呢
,一個星期也沒找到問題,謝謝各位老師解答!?。?/p>
問題解答
回答1:data為什么是login不應該是form表單嗎
回答2:好長相關文章:
1. docker - 如何修改運行中容器的配置2. docker網絡端口映射,沒有方便點的操作方法么?3. debian - docker依賴的aufs-tools源碼哪里可以找到?。?/a>4. docker-machine添加一個已有的docker主機問題5. docker綁定了nginx端口 外部訪問不到6. golang - 用IDE看docker源碼時的小問題7. docker 下面創建的IMAGE 他們的 ID 一樣?這個是怎么回事????8. docker鏡像push報錯9. docker-compose中volumes的問題10. node.js - nodejs debug問題