Ajax学习笔记——验证邮箱唯一性案例

Ajax学习笔记——验证邮箱唯一性案例

在node.js搭建的服务器进行

在这里插入图片描述

步骤:

  1. 获取文本框并为其添加离开焦点事件
  2. 离开焦点时,检测用户输入的邮箱地址是否符合规则
  3. 如果不符合规则,组织程序向下执行并给出提示信息
  4. 向服务器端发送请求,检测邮箱地址是否被别人注册
  5. 根据服务器返回值决定客户端显示何种提示信息

客户端代码:

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="utf-8">
	<title></title>
	<link rel="stylesheet" href="/assets/bootstrap/dist/css/bootstrap.min.css">
		<style type="text/css">
		p:not(:empty) {
			padding: 15px;
		}
		.container {
			padding-top: 100px;
		}
	</style>
</head>
<body>
	<div class="container">
		<div class="form-group">
			<label>邮箱地址</label>
			<input type="email" id="email" class="form-control" placeholder="请输入邮箱地址">
		</div>
		<!-- 错误 bg-danger 正确 bg-success-->
		<p id="info"></p>
	</div>
	<script src= "/js/ajax.js"></script>
	<script type="text/javascript">
	// 1.获取页面元素,文本框
	var emailInp = document.getElementById('email');
	var info = document.getElementById('info');

	// 2.添加离开焦点事件
	emailInp.onblur = function(){
		// 3.获取用户输入的地址值
		var email = this.value;
		// 4. 先判断输入的地址格式是否符合规则(使用正则表达式)
		var reg = /^[A-Za-z\d]+([-_.][A-Za-z\d]+)*@([A-Za-z\d]+[-.])+[A-Za-z\d]{2,4}$/;
		// 4.输入不对给提示,输入对就发送到服务器去判断
		if(!reg.test(email)){
			//给出用户提示
			info.innerHTML = '请输入符合规则的邮箱地址';
			//让提示信息显示为错误提示信息的样式
			info.className = 'bg-danger';
			//阻止程序向下执行
			return;
		}

		ajax({
			type:'get',
			url:'http://localhost:3000/verifyEmailAdress',
			data:{
				email:email,
			},
			success:function(result){
				console.log(result);
				info.innerHTML = result.message;
				info.className = 'bg-success';
			},
			error:function(result){
				console.log(result);
				info.innerHTML = result.message;
				info.className = 'bg-danger';
			}
		});

	}
	</script>
</body>
</html>

服务器代码:

// 引入express框架
const express = require('express');

// 路径处理模块
const path = require('path');

//创建web服务器
const app = express();

//静态资源访问服务功能
app.use(express.static(path.join(__dirname,'public')));

//邮箱地址验证
app.get('/verifyEmailAdress',(req,res)=>{
	//接收客户端传递过来的邮箱地址
	const email = req.query.email;
	//判断邮箱地址注册过的情况
	if(email == 'lisi@lisi.cn' ){
		res.status(400).send({message:'邮箱地址已经注册过了,请更换其他邮箱地址'});
	}else{
		res.send({message:'恭喜,邮箱地址可用'})  //这返回的是一个对象
	}
})
//监听
app.listen(3000);
console.log('服务器启动成功');
  • 服务器返回的是一个对象
  • p: not(:empty) { padding: 15px; } ——这句什么意思啊
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,以下为B站黑马JavaScript的Ajax案例代码——图书管理案例搜索事件: ```javascript /** * 搜索事件 */ function searchBook() { // 获取搜索框内容 var searchInput = document.querySelector("#searchInput"); var keywords = searchInput.value.trim(); // 如果搜索框内容为空,提示用户 if (keywords == "") { alert("请输入关键字进行搜索!"); return; } // 发送Ajax请求 var xhr = new XMLHttpRequest(); // 创建XmlHttpRequest对象 xhr.open("GET", "/api/book/search?keywords=" + keywords, true); // 配置请求 xhr.onreadystatechange = function () { if (xhr.readyState == 4 && xhr.status == 200) { // 处理响应数据 var books = JSON.parse(xhr.responseText); // 将响应数据转成JavaScript对象 renderBooks(books); // 渲染图书列表 } }; xhr.send(null); // 发送请求 } /** * 渲染图书列表 * @param {*} books 图书列表数据 */ function renderBooks(books) { // 获取图书列表容器 var bookList = document.querySelector("#bookList"); var html = ""; if (books.length > 0) { // 遍历图书列表数据,生成HTML字符串 for (var i = 0; i < books.length; i++) { html += '<tr>'; html += '<td>' + books[i].title + '</td>'; html += '<td>' + books[i].author + '</td>'; html += '<td>' + books[i].category + '</td>'; html += '<td>' + books[i].price + '</td>'; html += '<td>' + books[i].publisher + '</td>'; html += '</tr>'; } } else { // 如果没有搜索到任何图书,提示用户 html = '<tr><td colspan="5">没有搜索到任何图书!</td></tr>'; } // 将生成的HTML字符串添加进图书列表容器 bookList.innerHTML = html; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值