Ajax编程之模板引擎与FormDate的使用

Ajax编程之模板引擎与FormDate的使用

1 模板引擎的使用

作用:使用模板引擎提供的模板语法,可以将数据和 HTML 拼接起来。
使用步骤:

<!-- 1. 将模板引擎的库文件引入到当前页面 -->
	<script src="/js/template-web.js"></script>
<body>
	<div id="container"></div>
	<!-- 2.准备art-template模板 -->
	<script type="text/html" id="tpl">
		<h1>{{username}} {{age}}</h1>
	</script>
	<script type="text/javascript">
		// 3.告诉模板引擎将那个数据和哪个模板进行拼接
		// 1) 模板id 2)数据 对象类型
		// 方法的返回值就是拼接好的html字符串
		var html = template('tpl', {username: 'zhangsan', age: 30});
		//将标签放入id是container的容器里面
		document.getElementById('container').innerHTML = html;
	</script>
</body>	

注意:需要下载 art-template 模板引擎库文件并在 HTML 页面中引入库文件。

2 Ajax的案例应用

2.1 验证邮箱地址的唯一性

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

2.2 搜索框内容自动提示

  1. 获取搜索框并为其添加用户输入事件
  2. 获取用户输入的关键字
  3. 向服务器端发送请求并携带关键字作为请求参数
  4. 将响应数据显示在搜索框底部

2.3 省市区联动

  1. 通过接口获取省份信息;
  2. 使用JavaScript获取到省市区下拉框元素;
  3. 将服务器端返回的省份信息显示在下拉框中;
  4. 为下拉框元素添加表单值改变事件(onchange);
  5. 当用户选择省份时,根据省份id获取城市信息;
  6. 当用户选择城市时,根据城市id获取县城信息。

3 FormDate的使用

3.1 FormDate对象的使用方法

FromDate对象的使用:

  • 1.模拟HTML表单,相当于将HTML表单映射成表单对象,自动将表单对象中的数据拼接成请求参数的格式。
  • 2.异步上传二进制文件。

html代码如下:

<!-- 1.创建普通的html表单 -->
	<form id="form">
		<input type="text" name="username">
		<input type="password" name="password">
		<input type="button" id="btn" value="提交">
	</form>
<!-- 2.HTML 表单转化为 formData 对象 -->
<script type="text/javascript">
		// 获取按钮
		var btn = document.getElementById('btn');
		// 获取表单
		var form = document.getElementById('form');
		// 为按钮添加点击事件
		btn.onclick = function () {
			// 将普通的html表单转换为表单对象
			var formData = new FormData(form);
			// 创建ajax对象
			var xhr = new XMLHttpRequest();
			// 对ajax对象进行配置
			xhr.open('post', 'http://localhost:3000/formData');
			// 发送ajax请求
			xhr.send(formData);
			// 监听xhr对象下面的onload事件
			xhr.onload = function () {
				// 对象http状态码进行判断
				if (xhr.status == 200) {
					console.log(xhr.responseText);
				}
			}
		}
	</script>

服务器端的代码如下:

const formidable = require('formidable');

app.post('/formData', (req, res) => {
	// 创建formidable表单解析对象
	const form = new formidable.IncomingForm();
	// 解析客户端传递过来的FormData对象
	form.parse(req, (err, fields, files) => {
		res.send(fields);
	});
});

注意:

  • 1.Formdata 对象不能用于 get 请求,因为对象需要被传递到 send 方法中,而 get 请求方式的请求参数只能放在请求地址的后面。
  • 2.服务器端 bodyParser 模块不能解析 formData 对象表单数据,我们需要使用 formidable 模块进行解析。

3.2 FormDate对象下的实例方法

// 1.获取表单对象中属性的值
formData.get('key');
// 2.设置表单对象中属性的值
formData.set('key', 'value');
// 3.删除表单对象中属性的值
formData.delete('key');
// 4.向表单对象中追加属性值
 formData.append('key', 'value');

注意:set 方法与 append 方法的区别是,在属性名已存在的情况下,set 会覆盖已有键名的值,append会保留两个值。

3.3 FormDate对象实现二进制文件上传

FormData 文件上传文件即时预览,显示进度:

<div class="container">
		<div class="form-group">
			<label>请选择文件</label>
			<input type="file" id="file">
			<div class="padding" id="box">
				<!--<img src="" class="img-rounded img-responsive">-->
			</div>
			<div class="progress">
				<div class="progress-bar" style="width: 0%;" id="bar">0%</div>
			</div>
		</div>
	</div>
<script type="text/javascript">
	// 获取文件选择控件
	var file = document.getElementById('file');
	// 获取进度条元素
	var bar = document.getElementById('bar');
	// 获取图片容器
	var box = document.getElementById('box');
	// 为文件选择控件添加onchanges事件
	// 在用户选择文件时触发
	file.onchange = function () {
		// 创建空的formData表单对象
		var formData = new FormData();
		// 将用户选择的文件追加到formData表单对象中
		formData.append('attrName', this.files[0]);
		// 创建ajax对象
		var xhr = new XMLHttpRequest();
		// 对ajax对象进行配置
		xhr.open('post', 'http://localhost:3000/upload');
		// 在文件上传的过程中持续触发
		xhr.upload.onprogress = function (ev) {
			// ev.loaded 文件已经上传了多少
			// ev.total  上传文件的总大小
			var result = (ev.loaded / ev.total) * 100 + '%';
			// 设置进度条的宽度
			bar.style.width = result;
			// 将百分比显示在进度条中
			bar.innerHTML = result;
			}
		// 发送ajax请求
		xhr.send(formData);
		// 监听服务器端响应给客户端的数据
		xhr.onload = function () {
			// 如果服务器端返回的http状态码为200
			// 说明请求是成功的
			if (xhr.status == 200) {
				// 将服务器端返回的数据显示在控制台中
				var result = JSON.parse(xhr.responseText);
				// 动态创建img标签
				var img = document.createElement('img');
				// 给图片标签设置src属性
				img.src = result.path;
				// 当图片加载完成以后
				img.onload = function () {
					// 将图片显示在页面中
					box.appendChild(img);
				}
			}
		}			
	}
	</script>

服务器端代码:

// 实现文件上传的路由
app.post('/upload', (req, res) => {
	// 创建formidable表单解析对象
	const form = new formidable.IncomingForm();
	// 设置客户端上传文件的存储路径
	form.uploadDir = path.join(__dirname, 'public', 'uploads');
	// 保留上传文件的后缀名字
	form.keepExtensions = true;
	// 解析客户端传递过来的FormData对象
	form.parse(req, (err, fields, files) => {
		// 将客户端传递过来的文件地址响应到客户端
		res.send({
			path: files.attrName.path.split('public')[1]
		});
	});
});
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值