ES6 Promise 和 Async/await的使用、事件委
2020-01-25 本文已影响0人
wdapp
//事件委托
window.onload = function(){
var oUl = document.getElementById("ul1");
oUl.onclick = function(ev){
var ev = ev || window.event;
var target = ev.target || ev.srcElement;
if(target.nodeName.toLowerCase() == 'li'){
alert(123);
alert(target.innerHTML);
}
}
}
//Promise
// 1请求
function getData1 () {
return new Promise(function (resolve, reject) {
setTimeout(() => {
console.log('1执行了')
resolve('请求到模拟数据1111拉')
}, 2000)
})
}
// 2请求
function getData2 (params) {
return new Promise(function (resolve, reject) {
setTimeout(() => {
console.log('2执行了')
resolve('请求到模拟数据22222拉!params:' + params)
}, 1500)
})
}
function promiseDemo () {
getData1()
.then(res => {
return getData2(res)
})
.then(res => {
console.log(res)
})
}
promiseDemo()
// 1执行了
// 2执行了
// 请求到模拟数据22222拉!params:请求到模拟数据1111拉 用时 3500 ms
//async+await
async function asyncDemo () {
const r1 = await getData1()
const r2 = await getData2(r1)
console.log(r2)
}
// 1执行了
// 2执行了
// 请求到模拟数据22222拉!params:请求到模拟数据1111拉 用时 3500 ms
在计算机科学中,二叉树(英语:Binary tree)是每个节点最多只有两个分支(不存在分支度大于2的节点)的树结构。通常分支被称作“左子树”和“右子树”。二叉树的分支具有左右次序,不能颠倒。
上面是来自维基百科的解释。而每一个节点的值总大于左子树的值,而小于右子树的值的二叉树就叫排序二叉树。比如:那么该如何创建一棵排序二叉树呢?
function Btree() {
// 节点对象
var Node = function(key) {
this.key = key;
this.right = null;
this.left = null;
};
// 初始化根节点
var root = null;
var insertnode = function(node, newnode) {
// 判断插到左子树中还是右子树中
if(newnode.key < node.key) {
if(node.left === null) {
node.left = newnode;
} else {
insertnode(node.left, newnode);
}
} else {
if(node.right === null) {
node.right = newnode;
} else {
insertnode(node.right, newnode);
}
}
};
this.insert = function(key) {
var newNode = new Node(key);
// 判断插入的是否是根节点
if(root === null) {
root = newNode;
} else {
insertnode(root, newNode);
}
};
}我们可以看到插入到二叉树的过程就是排序的过程,又如何把其输(遍历)出来呢。遍历可分为:
前序遍历
中序遍历
后序遍历我们先看中序遍历是如何实现的,只需要在Btree中加入以下两个方法
var zhongxu = function(node, callback) {
if(node !== null) {
zhongxu(node.left, callback);
callback(node.key);
zhongxu(node.right, callback);
}
};
this.zhongxubianli = function(callback) {
zhongxu(root, callback);
}而前序后序与中序的差别不过在于callback方法的先后,即
前序就是先输出值再依次遍历左右子树
中序就是先遍历左子树再输出值然后再遍历右子树
后序就是先遍历左右子树再输出值
// 前序遍历
var qianxu = function(node, callback) {
if(node !== null) {
callback(node.key);
zhongxu(node.left, callback);
zhongxu(node.right, callback);
}
};// 后序遍历
var houxu = function(node, callback) {
if(node !== null) {
zhongxu(node.left, callback);
zhongxu(node.right, callback);
callback(node.key);
}
};测试
var nodes = [8,2,4,5,7,13,11,9,14];
var btree = new Btree();
nodes.forEach(function(key) {
btree.insert(key);
})
var callback = function(key) {
console.log(key);
};
btree.zhongxubianli(callback);结果就是:
以上就是js的排序二叉树实现过程。
-
第一步:创建测试文件。
image -
第二步:创建数据文件,用测试文件发起请求测试数据。
image -
第三步:配置Charles,Proxy->Proxy Setting->HTTP Proxy->Port (配置端口号任意,不要于本机其他端口冲突)
image -
第四部:配置手机代理
image -
第五部:手机和电脑链接同一个wifi,在统一网段下,启动xampp服务器,手机通过ip访问测试文件,请求的数据就会被抓包工具charles拿到。
image