当前位置: 首页 > news >正文

贵阳奇点未来网站建设企业年报查询官网入口

贵阳奇点未来网站建设,企业年报查询官网入口,网站入口你明白我的意思吧,wordpress ios版文章目录 var,let,const严格模式数据类型运算符事件常用对象函数绑定call() ,apply(),bind() 闭包浏览器中事件循环回调和异步Promiseasync和await DOMBOMAjax var,let,const let是var的升级版本,对于块作用域,var无法进行限制,let不会存在该…

文章目录

  • var,let,const
  • 严格模式
  • 数据类型
  • 运算符
  • 事件
  • 常用对象
  • 函数绑定
    • call() ,apply(),bind()
  • 闭包
  • 浏览器中事件循环
  • 回调和异步
    • Promise
    • async和await
  • DOM
  • BOM
  • Ajax

var,let,const

let是var的升级版本,对于块作用域,var无法进行限制,let不会存在该问题

另外对于var的声明会进行提升,初始化不会进行提升

严格模式

在脚本或者函数开头添加"use strict"

数据类型

类型描述
numberjs里12==12.0 因为只有一种数字类型
string
boolean
undefined没有值的变量
object
function

注意:NaN和任何值都不相等

运算符

= 前者会自动转类型,后者会严格比较类型

算符描述
typeof返回变量的类型。
instanceof返回 true,如果对象是对象类型的实例。

事件

严格意义上指的是html的DOM事件,可以绑定js函数

onchangeHTML 元素已被改变
onclick用户点击了 HTML 元素
onmouseover用户把鼠标移动到 HTML 元素上
onmouseout用户把鼠标移开 HTML 元素
onkeydown用户按下键盘按键
onload浏览器已经完成页面加载

参考手册参照如下:

https://www.w3school.com.cn/jsref/dom_obj_event.asp

常用对象

数组
let array = [1,'2'];日期
let date = new Date();JSON对象
var obj = JSON.parse(text);  // JSON字符串转对象
var jsonText = JSON.stringify(book); //对象转JSON字符串Set对象
const letters = new Set(["a","b","c"]);
、
Map对象
const maps= new Map([[1],[2]])

函数绑定

call() ,apply(),bind()

call() 方法分别接受参数。

apply() 方法接受数组形式的参数。

call和apply是每个函数的方法,可以修改主体对象引用

函数回调时this会丢失,此时用bind函数

闭包

js中只有全局作用域和函数作用域

如果想实现一个私有的变量,则需要用到闭包(有权访问父作用域的函数)

var add = (function () {var counter = 0;return function () {return counter += 1;}
})();add();
add();
add();// 计数器目前是 3 

浏览器中事件循环

1.浏览器中JS是单线程的,会将同步代码按顺序放在执行栈,依次执行,遇到异步任务时交给其他线程处理,

待当前执行栈所有同步代码执行完后,从任务队列(存放已完成的异步任务)循环检测并取出回调加入执行栈继续执行,有异步任务再交给其他线程,循环往复

2.宏任务和微任务队列是2个不同的队列

事件循环的过程中,执行栈在同步代码执行完成后,优先检查微任务队列是否有任务需要执行,如果没有,再去宏任务队列检查是否有任务执行,如此往复。微任务一般在当前循环就会优先执行,而宏任务会等到下一次循环,因此,微任务一般比宏任务先执行,并且微任务队列只有一个,宏任务队列可能有多个。另外我们常见的点击和键盘等事件也属于宏任务。

常见宏任务 setTimeout(),setInterval(0)

常见微任务 promise.then() promise.catch()

当然这个事件循环机制在浏览器和nodejs里不太一样,具体问题具体分析

回调和异步

1.回调就是函数入参里有函数

2.异步函数

setTimeout() 等待超时

setInterval() 等待间隔

一般异步都是用Promise对象

Promise

new Promise() 执行同步方法

new Promise((resolve,reject)=>{resolve()reject()
}).then(a=>{}).catch(e=>{consoloe.log(e)
})

then() ,catch() 执行异步方法

一般使用都是框架封装的,底层都是用的Promise对象

async和await

async修饰异步函数,修饰返回Promise.resolve(返回值) 得到一个promise对象

await只能用在async函数里,修饰一个Promise对象,如果不是promise对象,会自动修饰Promise.resolve()

await可以理解为then的语法糖,也是一个微任务,但会暂时阻塞后面的代码(这里的阻塞个人理解是后面的代码还是会放到执行栈中,在await修饰的微任务执行完后会立刻执行),否则下面的代码执行顺序无法解释…


async function async1() {console.log('async1 start')let a=await async2()console.log(a)console.log('async1 end')
}async function async2() {console.log('async2')return "async2 finish"
}console.log('script start')
setTimeout(function() {console.log('setTimeout')
}, 0)async1(); new Promise( function( resolve ) {console.log('promise1')resolve();
} ).then( function() {console.log('promise2')
} )console.log('script end')script start
async1 start
async2
promise1
script end
//上面为同步任务
async2 finish //微任务1
async1 end  //同步任务
promise2 //微任务2
setTimeout //宏任务

DOM

就是html => js对象, document对象,后续基本都用的框架封装,原生的基本用不到

BOM

浏览器提供的对象

window对象

screen对象

location对象

navigator对象

history对象

弹出框方法 alert(),confirm(),prompt()

计时器方法(也是window对象提供的方法)

setTimeout(function, milliseconds)

在等待指定的毫秒数后执行函数。

setInterval(function, milliseconds)

cookie是document对象的属性,操纵cookie

Ajax

浏览器提供的http线程,使用XMLHttpRequest 对象会遇到跨域问题,url请求和当前网页必须同域。

经验上我感觉大多是用框架封装后的Ajax进行http请求

// 创建 XMLHttpRequest 对象
const xhttp = new XMLHttpRequest();// 定义回调函数
xhttp.onload = function() {// 您可以在这里使用数据
}// 发送请求
xhttp.open("GET", "ajax_info.txt");
xhttp.send();
http://www.15wanjia.com/news/191457.html

相关文章:

  • 佛山提供网站设计报价宣传策划方案
  • 做阅读理解的网站食品网站建设项目的预算
  • 净水设备 技术支持 东莞网站建设海报设计说明万能模板
  • 专业的外贸网站建设公司价格网站建设教程(任务2签订网站建设合同)题库
  • 河北网站建设制作wordpress 新浪博客
  • 简历生成网站ui设计师工作流程
  • 建设拼多多一样网站需要多少钱建设网站网站设计
  • 山东金城建设网站黄骅贴吧金宝
  • 新乡做网站公司哪家好域名注册的网站都有哪些
  • 内容导购网站模板xx网站建设策划方案
  • 北京人才招聘网站德阳市建设局官方网站
  • 高效简便的网站开发网络推广需要多少钱
  • 专业做网站公司济南dw个人网页设计
  • 华贸中心网站谁做的公司网站优化
  • 网站建设需求分析网站seo查询工具
  • 诸暨有哪些好网站制作公司巴中 网站建设
  • 企业的网站特点2019网站怎么做
  • 医院网站建设报价表山东济宁
  • 网站建设方案企业网站等保建设
  • 广州天呈网站建设衡水网站制作公司
  • 深圳网站公司制作做app需要什么软件
  • 石家庄网站设计网站维护seo外贸网站建设
  • pc网站wordpress主题无法显示
  • 公司建的站加油违法吗佛山市顺德区建设局网站
  • 怎么加php网站登陆源码wordpress 密码明文
  • 单位网站备案网站建设论坛社区
  • 企业营销网站模板头像设计制作器
  • 上海网站高端定制规划和设计一个网站
  • 北海哪家做网站dedecms网站地图前台路径不修改
  • 网站建设 中企动力烟台网站建设价格对比单