使用ajax,xhr却没有响应
1.项目中用到了ajax。结果测试时候发现页面在两款浏览器中表现不一:360浏览器可以顺利实现弹窗(alert)效果,火狐浏览器却一点效果全无。但是他们都有一个共同特点:在浏览器的调试模式(F12)的网络选项xhr下没有得出任何的数据,而在网络的全部、html、css、js这些地方都可以看到有数据,包括index首页(POST),其他资源都是以GET获得。
2.使用了ThinkPHP的自动验证功能,错误会自动返回信息,包括没有输入用户名或没有输入密码,但是我没对账号密码进行比对,也不知道为什么在360浏览器中用户名和密码我随便乱输了数据,结果发现一个空白alert对话框出来,也不知道这是什么回事?
3.360浏览器中alert对话框出现的时候,xhr还是有数据的,但是当alert对话框点击确定后,xhr数据就随之消失。
代码如下:
(1)login.js
<code>//前端登录业务类 var login={ checkUser:function(){ //获取登录页面中的输入数据 var userName=$('input[name="username"]').val(); var userPass=$('input[name="userpass"]').val(); //使用ajax var url="/stfjzd-15/index.php/Home/Index/checkUser"; var data={"username":userName,"userpass":userPass}; $.post(url,data,function(result){ //$("#result").html(data.info).show(); //$("#result").fadeOut(4000); if(result.status){ alert(result.info); }else{ //alert(2); alert(result.info); } },"json"); } }</code>
(2)IndexController.class.php
<code><?php namespace Home\Controller; use Think\Controller; class IndexController extends Controller { public function index(){ $this->display(); } //用户验证 public function checkUser(){ //接收变量,默认htmlspecialchars过滤 $userName=I("post.username"); $userPass=I("post.userpass"); $User=D("Stuser"); //ThinkPHP的自动验证必须使用create()才能启用 if(!$User->create()){ return $this->error($User->getError()); //exit($User->getError()); } } //空操作 public function _empty(){ echo "页面不存在,请检查您输入的路径是否正确,我要返回<a href="%22._PHP_FILE_.%22" alt="返回首页" title="返回首页">首页</a>"; } }</code>
(3)StuserModel.class.php
<code><?php namespace Home\Model; use Think\Model; //用户表模型 class StuserModel extends Model{ //构造函数创建模型 public function __construct(){ $this->DB=M("Stuser"); } //ThinkPHP的表单自动验证 protected $_validate=array( array("username","require","用户名不能为空"), array("userpass","require","密码不能为空"), ); } ?></code>
回复内容:
1.项目中用到了ajax。结果测试时候发现页面在两款浏览器中表现不一:360浏览器可以顺利实现弹窗(alert)效果,火狐浏览器却一点效果全无。但是他们都有一个共同特点:在浏览器的调试模式(F12)的网络选项xhr下没有得出任何的数据,而在网络的全部、html、css、js这些地方都可以看到有数据,包括index首页(POST),其他资源都是以GET获得。
2.使用了ThinkPHP的自动验证功能,错误会自动返回信息,包括没有输入用户名或没有输入密码,但是我没对账号密码进行比对,也不知道为什么在360浏览器中用户名和密码我随便乱输了数据,结果发现一个空白alert对话框出来,也不知道这是什么回事?
3.360浏览器中alert对话框出现的时候,xhr还是有数据的,但是当alert对话框点击确定后,xhr数据就随之消失。
代码如下:
(1)login.js
<code>//前端登录业务类 var login={ checkUser:function(){ //获取登录页面中的输入数据 var userName=$('input[name="username"]').val(); var userPass=$('input[name="userpass"]').val(); //使用ajax var url="/stfjzd-15/index.php/Home/Index/checkUser"; var data={"username":userName,"userpass":userPass}; $.post(url,data,function(result){ //$("#result").html(data.info).show(); //$("#result").fadeOut(4000); if(result.status){ alert(result.info); }else{ //alert(2); alert(result.info); } },"json"); } }</code>
(2)IndexController.class.php
<code><?php namespace Home\Controller; use Think\Controller; class IndexController extends Controller { public function index(){ $this->display(); } //用户验证 public function checkUser(){ //接收变量,默认htmlspecialchars过滤 $userName=I("post.username"); $userPass=I("post.userpass"); $User=D("Stuser"); //ThinkPHP的自动验证必须使用create()才能启用 if(!$User->create()){ return $this->error($User->getError()); //exit($User->getError()); } } //空操作 public function _empty(){ echo "页面不存在,请检查您输入的路径是否正确,我要返回<a href="%22._PHP_FILE_.%22" alt="返回首页" title="返回首页">首页</a>"; } }</code>
(3)StuserModel.class.php
<code><?php namespace Home\Model; use Think\Model; //用户表模型 class StuserModel extends Model{ //构造函数创建模型 public function __construct(){ $this->DB=M("Stuser"); } //ThinkPHP的表单自动验证 protected $_validate=array( array("username","require","用户名不能为空"), array("userpass","require","密码不能为空"), ); } ?></code>
用$this->ajaxReturn()
或者json_encode
试试

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제









PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

CakePHP는 오픈 소스 MVC 프레임워크입니다. 이를 통해 애플리케이션 개발, 배포 및 유지 관리가 훨씬 쉬워집니다. CakePHP에는 가장 일반적인 작업의 과부하를 줄이기 위한 여러 라이브러리가 있습니다.

이 튜토리얼은 PHP를 사용하여 XML 문서를 효율적으로 처리하는 방법을 보여줍니다. XML (Extensible Markup Language)은 인간의 가독성과 기계 구문 분석을 위해 설계된 다목적 텍스트 기반 마크 업 언어입니다. 일반적으로 데이터 저장 AN에 사용됩니다
