编译完成后(先分配给变量空间和function(){}命名的函数,var = function(){}这种函数也仅仅只是分配了个空间,还没有赋值个函数给他!),调用了若不是undefined就执行, js是同步的单线程语言,一般是按照代码的顺序,从上到下的执行已表名要执行的函数.然后,将他们插入队列中(也就是js引擎的执行队列中),按队列顺序执行,.当遇到了异步的调用时候,只有队列中同步函数执行完之后才会执行异步的,如: var t = true; window.setTimeout(funct…
1,什么是单线程,和异步有什么关系 单线程-只有一个线程,只能做一件事 单线程的原因:避免DOM 渲染的冲突 浏览器需要渲染DOM JS 可以修改DOM 结构 JS 执行的时候,浏览器DOM 渲染会暂停 两段JS 也不能同时执行(都修改DOM 就冲突了) webworker支持多线程,但是不能访问DOM 怎么解决:用异步,提高性能.但是异步的代码会有很多比较多难以理解的问题,比如 没有按照我们代码的顺序执行,可读性差 callback中不同意模块化,易出现回调地狱. 我们平常的工作中常见的一步的…
console.log('111'); setTimeout(()=>{ console.log('222') },1000); console.log('333'); setTimeout(()=>{ console.log('444') },0); console.log(555); 就是执行这样一段js代码 , 打印出来的结果是 : 111 -> 333 -> 555 -> 444 -> 222 (结果就是我们理论起来 setTimeout 到底是同步还是异步的…
阅读目录 vue自定义指令clickoutside.js的理解 回到顶部 vue自定义指令clickoutside.js的理解 vue自定义指令请看如下博客: vue自定义指令 一般在需要 DOM 操作时我们都需要使用自定义指令的方式去实现,当然一些特殊的事件监听也可以使用指令,例如监听外部点击事件: 我们可以看下 clickoutside.js 如何实现的,如下代码: const clickoutsideContext = '@@clickoutsideContext'; export def…
js面向对象理解 ECMAScript 有两种开发模式:1.函数式(过程化),2.面向对象(OOP).面向对象的语言有一个标志,那就是类的概念,而通过类可以创建任意多个具有相同属性和方法的对象.但是,ECMAScript 没有类的概念,因此它的对象也与基于类的语言中的对象有所不同. js(如果没有作特殊说明,本文中的js仅包含ES5以内的内容)本身是没有class类型的,但是每个函数都有一个prototype属性.prototype指向一个对象,当函数作为构造函数时,prototype则起到类似…
JS之理解继承:https://segmentfault.com/a/1190000010468293 1.call继承,也叫借用构造函数.伪造对象或是经典继承.call继承回把父类的私有属性和方法继承给子类私有:父类公有属性(原型上的属性)无关.当然这里的call也可以用apply. //父类F //子类S function S(){ F.call(this) }//原理就是改变F中的this指向,指向S的实例,子类会获得父类F的私有属性和方法 2.原型链继承:在1中通过call继承到了父类的…
你应该知道,javascript语言是一门“单线程”的语言,不像java语言,类继承Thread再来个thread.start就可以开辟一个线程,所以,javascript就像一条流水线,仅仅是一条流水线而已,要么加工,要么包装,不能同时进行多个任务和流程.那么这里说的同步和异步到底是什么呢?如果你真的不懂,我希望你认真读完这篇文章.其实我个人觉得js官方的文档在使用两个词的时候并不准确,包括很多其他词汇,都只是听起来高深,但实际应用好像跟这些词没半毛钱关系.例如“事件委托”这个词,不知道的人乍…
你应该知道,javascript语言是一门“单线程”的语言,不像java语言,类继承Thread再来个thread.start就可以开辟一个线程,所以,javascript就像一条流水线,仅仅是一条流水线而已,要么加工,要么包装,不能同时进行多个任务和流程. 那么这里说的同步和异步到底是什么呢?如果你真的不懂,我希望你认真读完这篇文章.其实我个人觉得js官方的文档在使用两个词的时候并不准确,包括很多其他词汇,都只是听起来高深,但实际应用好像跟这些词没半毛钱关系.例如“事件委托”这个词,不知道的人…
js引擎在执行的时候是单线程的,这是大家都知道的.我们先来看一段代码: <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>JavaScript</title> <script> //第一段 for (var i = 10000; i >= 0; i--) {…
js的同步和异步问题通常是指ajax的回调,如果是同步调用,程序在发出ajax调用后就会暂停,直到远程服务器产生回应后才会继续运行.而如果是异步调用,程序发出ajax调用后不会暂停,而是立即执行后面的代码,服务器返回信息后会自动触发回调函数进行处理.相比较而言,异步调用的性能最佳,程序不会出现卡顿的现象,而同步调用则通常用于需要立即获得结果并实时处理的情况.…