发表于: 2018-11-30 22:32:44

1 764


今天完成的事情:(一定要写非常细致的内容,比如说学会了盒子模型,了解了Margin)

 

javaScript是一门单线程的非阻塞的脚本语言

单线程意味着,javascript代码在执行的任何时候,都只有一个主线程来处理所有的任务。

 

1.执行栈与事件队列

javascript代码执行的时候会将不同的变量存于内存中的不同位置:堆(heap)和栈(stack)中来加以区分。

其中,堆里存放着一些对象。而栈中则存放着一些基础类型变量以及对象的指针。

当我们调用一个方法的时候,js会生成一个与这个方法对应的执行环境(context),又叫执行上下文。

这个执行环境中存在着这个方法的私有作用域,上层作用域的指向,方法的参数,这个作用域中定义的变量以及这个作用域的this对象。

js是单线程的,同一时间只能执行一个方法,同一时间只能执行一个方法,于是这些方法被排队在一个单独的地方。这个地方被称为执行栈

执行顺序

当一个脚本第一次执行的时候,js引擎会解析这段代码,并将其中的同步代码按照执行顺序加入执行栈中,然后从头开始执行。如果当前执行的是一个方法,那么js会向执行栈中添加这个方法的执行环境,然后进入这个执行环境继续执行其中的代码。当这个执行环境中的代码执行完毕并返回结果后,js会退出这个执行环境并把这个执行环境销毁,回到上一个方法的执行环境。。这个过程反复进行,直到执行栈中的代码全部执行完毕。

 

js引擎遇到一个异步事件后并不会一直等待其返回结果,而是会将这个事件挂起,继续执行执行栈中的其他任务。当一个异步事件返回结果后,js会将这个事件加入与当前执行栈不同的另一个队列,我们称之为事件队列。被放入事件队列不会立刻执行其回调,而是等待当前执行栈中的所有任务都执行完毕, 主线程处于闲置状态时,主线程会去查找事件队列是否有任务。如果有,那么主线程会从中取出排在第一位的事件,并把这个事件对应的回调放入执行栈中,然后执行其中的同步代码...,如此反复,这样就形成了一个无限的循环。这就是这个过程被称为“事件循环(Event Loop)”的原因。

 

以下事件属于任务:

setInterval()

setTimeout()

以下事件属于任务

new Promise()

new MutaionObserver()

找了一下JS获取input元素的value值


<html> 

 <head> 

 <script language="javascript"> 

  function print(){ 

   var a=myform.name.value; 

   alert(a); 

  } 

 </script> 

 </head> 

 <body> 

  <form name="myform"> 

   <input type="text" name="name" id="nn" /> 

   <input type="button" name="button" value="获取" onclick="print()" /> 

  </form>   

 </body> 

</html>  


了解了一下正则表达式,了解不多,明天在仔细看看

RegExp 是正则表达式的缩写。

当您检索某个文本时,可以使用一种模式来描述要检索的内容。RegExp 就是这种模式。

简单的模式可以是一个单独的字符。

更复杂的模式包括了更多的字符,并可用于解析、格式检查、替换等等。

您可以规定字符串中的检索位置,以及要检索的字符类型,等等。

明天计划的事情:(一定要写非常细致的内容) 

做js任务2
遇到的问题:(遇到什么困难,怎么解决的) 

暂无
收获:(通过今天的学习,学到了什么知识)

了解了获取input的信息


返回列表 返回列表
评论

    分享到