溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么在ThinkPHP框架中使用Ajax實(shí)現(xiàn)一個(gè)用戶名校驗(yàn)功能

發(fā)布時(shí)間:2021-04-13 17:06:58 來源:億速云 閱讀:140 作者:Leah 欄目:開發(fā)技術(shù)

本篇文章為大家展示了怎么在ThinkPHP框架中使用Ajax實(shí)現(xiàn)一個(gè)用戶名校驗(yàn)功能,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

在模板文件中通過ajax獲取到用戶名,然后在控制器中將用戶名與數(shù)據(jù)庫(kù)比較,返回校驗(yàn)結(jié)果給模板文件。

怎么在ThinkPHP框架中使用Ajax實(shí)現(xiàn)一個(gè)用戶名校驗(yàn)功能

模板文件路徑shop/Home/View/User/register.html

<!--register.html-->
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>Untitled Document</title>
<script type="text/javascript">
  var urlpath = "{$smarty.const.__CONTROLLER__}";
  //ajax無刷新方式校驗(yàn)用戶名
  function checkname(){
    //(1)獲取被校驗(yàn)的用戶名信息
    var nm = document.getElementById('User_username').value;
    //(2)ajax抓取到用戶名傳遞給服務(wù)器端進(jìn)行校驗(yàn)
    var xhr = new XMLHttpRequest();
    xhr.onreadystatechange = function(){
      if(xhr.readyState == 4){
        document.getElementById('namecheck').innerHTML = xhr.responseText;
      }
    }
    //tp框架使用模式:分組/控制器/操作方法/方法參數(shù)
    //xhr.open('get', "/shop/index.php/User/checkNM/" + nm);//默認(rèn)分組為Home
    xhr.open('get', urlpath + "/checkNM/" + nm);
  }
</script>
</head>
<body>
  <tr>
    <td>
      <label for="User_username">用戶名</label>
    </td>
    <td>
      <input type="text" name="username" value="" id="User_username" onblur="checkname()">
      <span id="namecheck">{$errorInfo.username|default:""}</span>
    </td>
  </tr>
</body>
</html>

控制器文件路徑shop/Home/Controller/User/UserController.class.php

<?php
//UserController.class.php
//命名空間
namespace Home\Controller;
use Think\Controller;
//前臺(tái)用戶控制器
class UserController extends Controller{
  //用戶名校驗(yàn)
  function checkNM($name){
    //在數(shù)據(jù)庫(kù)中根據(jù)條件查詢結(jié)果
    $info = D('User')->where("username='$name'")->find();
    if($info){
      echo "<span style='color:red'>用戶名已存在,請(qǐng)換一個(gè)</span>";
    }else {
      echo "<span style='color:green'>恭喜,用戶名可以使用</span>";
    }
    exit;
  }
}

上述內(nèi)容就是怎么在ThinkPHP框架中使用Ajax實(shí)現(xiàn)一個(gè)用戶名校驗(yàn)功能,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI