正常函数的调用

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>函数的调用</title>
</head>
<body>
<script>
function f1(){
console.log('1111111111111');
console.log('1111111111111');
console.log('1111111111111');
console.log('1111111111111');
console.log('1111111111111');
}
function f2(){
console.log('222222222222222');
console.log('222222222222222');
f1();
console.log('222222222222222');
console.log('222222222222222');
console.log('222222222222222');
}
function f3(){
console.log('3333333333333333');
console.log('3333333333333333');
f2();
console.log('3333333333333333');
console.log('3333333333333333');
console.log('3333333333333333');
}
f3()
</script>
</body>
</html>

调用顺序:

调用f3函数,输出2次33333,然后调用f2函数,输出2次22222,调用f1函数,输出5次1111111;
f1的代码执行完成后会回到被调用的位置接着执行代码,此时输出3次222222,然后回到f2被调用的位置,输出3次333
 

回调函数

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>回调函数</title>
</head>
<body>
<script> function getResult(n1,n2,fn){
var result = fn(n1,n2)
return result;
}
var res = getResult(120,230, function (a, b) {
return a + b;
})
console.log(res);
</script>
</body>
</html>

调用顺序:

调用getResult时传入3个参数,第3个是一个匿名函数,函数里面计算ab的和,getResult接受到120,230参数分别赋值给n1和n2,然后调用fn函数进行计算值,返回结果给result,返回result给res接收,最后控制台输出res就得到350了。

Get和Post请求的差异

封转AJAX异步发送请求的过程

目录结构:

myAjax.js

/*
1.创建异步对象
2. 设置请求行
3. 设置请求头
4. 设置请求体
5. 设置监视异步对象状态
*/ // 这种方式不好,参数固定死了,不灵活,顺序只能这样
// ajax是一个函数,如果引入到别的文件当中,有可能会靠变量或函数的污染 /* function ajax(params) {
var xhr = new XMLHttpRequest();
// 设置请求行
xhr.open('get', '/getStudentsJSON');
// 设置请求头
// get请求可以省略这一步
// 设置请求体
xhr.send(null);
// 监听异步对象状态
xhr.onreadystatechange = function () {
// 判断数据是否全部接收完成
if (xhr.status == 200 && xhr.readyState == 4) {
// 由于服务端响应过来的json数据是字符串类型的,这里需要把它转换成对象或者数组类型,使用JSON.parse()方法
var obj = JSON.parse(xhr.responseText);
console.log(obj);
}
}
} */ var $ = {
// 创建一个名为convert方法,把对象转换成拼接字符串的方法
convertTostring: function(obj){
var str = '';
for(var key in obj){
str += key + '=' + obj[key] + '&';
console.log(str);
}
console.log(str.slice(0,-1));
return str.slice(0,-1);
}, // 代码没问题
// 创建一个名为ajax方法,进行使用异步对象发送请求
ajax: function(params) { // 传入的参数是一个对象
// 这个parmas对象里面应该包括:type,url,data,callback
// 定义变量获取数据, 短路运算
var type = params.type || 'get'; // 获取请求的方式
var url = params.url || location.pathname; //location.href也可以; 获取要发送的目标地址
var data = this.convertTostring(params.data || {}); // 获取要发送的数据
var success = params.success;
var dataType = params.dataType || 'text/plain'; // 什么都没有就以纯字符串 // 创建异步AJAX对象
var xhr = new XMLHttpRequest(); if(type=='get'){
url = url+"?"+data; //http://baidu.com:3002/submit?userName=jack&passPWd=jack1234
data = null;
}
// 设置请求行
xhr.open(type, url);
// 设置请求头
if(type=='post'){
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
}
// get请求可以省略这一步
// 设置请求体
xhr.send(data); // 这里的data就是通过convertTostring方法拼接的字符串
// 监听异步对象状态
xhr.onreadystatechange = function () {
// 判断数据是否全部接收完成
if (xhr.status == 200 && xhr.readyState == 4) {
var res;
// 把服务器响应回来的数据进行判断然后保存起来
if(dataType =='json'){
res = JSON.parse(xhr.responseText)
}else if(dataType=='xml'){
res = xhr.responseXML;
}else{
res = xhr.responseText; // 当成纯文本字符串接收
}
success(res);
}
}
}
}

studentsJSON.html

<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>studentsJSON页面</title>
<!-- <script src="/assets/js/myAjax.js"></script> -->
<!-- 引入jQuery文件 -->
<script src="/assets/js/jquery-1.12.2.js"></script> </head> <body>
<h2>这是studentsJSON页面</h2>
<input type="button" id="btn" value="获取JSON数据">
<table border="1">
<thead>
<th>id</th>
<th>姓名</th>
<th>性别</th>
<th>年龄</th>
<th>专业</th>
<th>地址</th>
</thead>
<tbody>
<tr>
<td>1</td>
<td>小苏</td>
<td>男</td>
<td>18</td>
<td>前端</td>
<td>佛山</td>
</tr>
</tbody>
</table> <script>
// 查找元素
var btn = document.querySelector('#btn');
var tbody = document.querySelector('tbody'); // 给btn绑定点击事件
btn.addEventListener('click', function () {
$.ajax({
type: 'get',
url: '/getStudentsJSON',
dataType: 'json', // 告诉ajax函数,将返回来的数据以json的形式进行处理 // 创建一个方法
success: function (obj) {
var data = obj.data;
var str = '';
for (var i = 0; i < data.length; i++) {
// 套用ES6的模版快速拼接字符串
str += `
<tr>
<td>${data[i].id}</td>
<td>${data[i].name}</td>
<td>${data[i].gender}</td>
<td>${data[i].age}</td>
<td>${data[i].zhuanye}</td>
<td>${data[i].address}</td>
</tr>
`
}
// 渲染页面中的数据
tbody.innerHTML = str;
},
})
}) </script>
</body> </html>

studentsXML.html

<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>studentsXML页面</title>
<!-- 引入封转好的AJAX文件 -->
<script src="/assets/js/myAjax.js"></script>
</head> <body>
<h2>这是一个使用XML数据渲染的列表</h2>
<input type="button" id="btn" value="获取XML数据">
<table border="1">
<thead>
<th>id</th>
<th>姓名</th>
<th>性别</th>
<th>年龄</th>
<th>专业</th>
<th>地址</th>
</thead>
<tbody>
<tr>
<td>1</td>
<td>小苏</td>
<td>男</td>
<td>18</td>
<td>前端</td>
<td>佛山</td>
</tr>
</tbody>
</table> <script>
// 查找元素
var btn = document.querySelector('#btn');
var tbody = document.querySelector('tbody'); // 给按钮绑定点击事件
btn.addEventListener('click', function () {
// 调用ajax方法传入参数
$.ajax({
type: 'get', // 请求方式
url: '/getStudentsXML', // 服务器接口地址
dataType: 'xml', // 服务器返回的数据格式
success: function(obj){ // 回调函数
console.log(obj);
console.log(typeof(obj));
var items = obj.querySelector('items').children;
var str = '';
for(var i=0; i<items.length; i++){
str += `
<tr>
<td>${items[i].querySelector('id').innerHTML}</td>
<td>${items[i].querySelector('name').innerHTML}</td>
<td>${items[i].querySelector('gender').innerHTML}</td>
<td>${items[i].querySelector('age').innerHTML}</td>
<td>${items[i].querySelector('zhuanye').innerHTML}</td>
<td>${items[i].querySelector('address').innerHTML}</td>
</tr>
`
}
tbody.innerHTML = str;
}
}); }) </script>
</body> </html>
如果不想手动封装AJAX,可以使用JQuery,直接引入jQ文件,其他不需要改,直接$.ajax({传参})就可以了。

手动封装AJAX的更多相关文章

  1. 使用promise手动封装ajax函数

    最近在做一个单页应用,node和浏览器仅通过json传输数据,因为是只有自己用等于是锻炼一下自己,所以也不用考虑seo的问题,node端我已经写好了,但是浏览器端想要用ajax原生太麻烦,用封装的函数 ...

  2. 使用原生JS封装Ajax

    使用原生 的JS封装 Ajax,实现 仿JQuery的Ajax,post,get三种异步请求方式: var MAjax = { //根据浏览器创建异步对象 createXhr: function () ...

  3. 原生javascript封装ajax和jsonp

    在我们请求数据时,完成页面跨域,利用原生JS封装的ajax和jsonp: <!DOCTYPE html> <html lang="en"> <head ...

  4. AJAX编程-封装ajax工具函数

    即 Asynchronous [e'sɪŋkrənəs] Javascript And XML,AJAX 不是一门的新的语言,而是对现有技术的综合利用.本质是在HTTP协议的基础上以异步的方式与服务器 ...

  5. javascript 【封装AJAX】

    post function createXHR() { if (typeof XMLHttpRequest != 'undefined') { return new XMLHttpRequest(); ...

  6. 封装ajax原理

    封装ajax原理 首先处理 用户如果不传某些参数,设置默认值 type默认get 默认url为当前页 默认async方式请求 data数据默认为{} 处理用户传进来的参数对象 遍历,拼接成key=va ...

  7. 04.封装ajax

    <script> //封装ajax // 函数名 ajax // 函数的参数 // url: 请求的地址 // type: 请求的方式 get /post // data: 要上传的数据 ...

  8. 自定义封装ajax,复制即可用

    支持get.post请求 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> ...

  9. 封装ajax,让调用变得简单优化

    思考一下: 通常我们在使用ajax来发送接口请求时,每一次都会调用ajax固定的元素,比如data.url.method.success.error等.那么我们想一下能不能先把ajax封装起来,在每次 ...

随机推荐

  1. HTML5中的数据集dataset和自定义属性data-*

    在html5中可为所有元素添加一种自定义的属性,这种属性的前缀以data-开头,比如:data-name,目的是为元素提供与页面渲染无关,但与dom元素强相关的属性.添加完自定义属性后我们可以通过元素 ...

  2. JS random函数深入理解(转载)

    转载自:(本文对读者有帮助的话请移步支持原作者) http://www.cnblogs.com/starof/p/4988516.html 一.预备知识 Math.ceil();  //向上取整. M ...

  3. 群晖安装transmission

    首先 需要添加第三方的套件下载地址 http://packages.synocommunity.com/ 然后找到tr 根据需要设置文件夹路径 因为我需要跑rss,所以用到了flexget,先放这里 ...

  4. htmlunit第一个爬虫演示 目标网址http://ent.sina.com.cn/film/

    基本都要放弃了 springmvc 配置了htmlunit之后无法运行,都不能正常实例化webclient,但是突然想起来用maven应用程序测试一下 结果竟然就可以了.好吧,还是有希望的 大佬博客 ...

  5. 关于在页面得到的servlet验证码总是上一次保存在session中的

    在网上找到一份servlet产生验证码的代码,经过测试,发现在页面通过session.getAttribute()方法得到的验证码总是上一次保存在session中的,这样,它总比页面实际的验证码晚一拍 ...

  6. 2019-9-2-windows-10「设置」应用完整ms-settings快捷方式汇总

    title author date CreateTime categories windows-10「设置」应用完整ms-settings快捷方式汇总 lindexi 2019-09-02 12:57 ...

  7. Nginx 日志切割后无法记日志

    日志切割会向Nginx Pid发送一个信号重新打开日志文件,如果nginx.conf没有配置PID,切割日志后找不到PID文件,就会出问题

  8. Leetcode633.Sum of Square Numbers平方数之和

    给定一个非负整数 c ,你要判断是否存在两个整数 a 和 b,使得 a2 + b2 = c. 示例1: 输入: 5 输出: True 解释: 1 * 1 + 2 * 2 = 5 示例2: 输入: 3 ...

  9. SaaS launch Kit成回收宝和友盟云合作纽带,帮助提升3倍上云效率

    导语:叶飞表示,全球二手手机市场未来几年将发生巨大变革, 回收宝正进行积极布局.与阿里云开展紧密技术合作,回收宝期待成为这一变革的引领者. 7月26日,在阿里云上海峰会上,阿里云了发布SaaS生态战略 ...

  10. 记CRenderTarget:DrawText()绘制中文乱码的BUG及解决办法

    原文:记CRenderTarget:DrawText()绘制中文乱码的BUG及解决办法 转载请注明出处:http://www.cnblogs.com/Ray1024 一.问题描述 在MFC中使用Dir ...