JS中script词法分析

核心:JS中的script是分段执行的。

1 <script>
2     var i = 10;
3 </script>
4 <script>
5     alert(i);
6 </script>

上面的例子中,弹出结果10。因为在之前script语句段定义的变量和函数可以再其他script语句段中使用。在一个js程序中,可以有多个script语句段,那么它们如何工作呢?

script执行过程:

  1.读入第一个代码段

  2.编译(声明变量,声明函数,语法检查,语义检查,代码优化,分析并得到代码书)

  3.执行

  4.读入下一代码段

  5.编译

  6.执行

  7.读入下一代码段

  ......

  n.结束

举个例子来说

1 <script>
2     //例1
3     alert(i);
4 </script>
1 <script>
2     //例2
3     alert(i);
4     var i=10;
5 </script>

例1的代码执行后,什么都不会弹出,因为已经报错了。但例2的代码会弹出undefined。因为i已经声明但没有赋值。因为代码段是先编译再执行,编译负责生成,执行负责赋值。

区分编译错误和运行错误:

1 <script>
2     alert(i; //编译错误
3     alert(i);//运行错误
4     alert(‘hello‘);
5 </script>

但无论是哪种错误,当前代码段中的后面的代码都不执行。

无论是哪种错误,不会影响后面的代码段的执行。

编译错误时,当前代码段会停止,代码中所有声明全部无效。

运行错误时,前面的代码已经执行完毕,不会影响该代码段内前面的内容。

时间: 2024-10-12 03:18:21

JS中script词法分析的相关文章

js中&lt;script&gt;放置问题

今天做项目的时候,使用document.getElementById('id'),但是得不到页面控件的值,因为是服务器控件,所以将id换成<%= id.ClientID%>,但是重新加载后发现还是无法获取指定控件的值.中途还尝试了jquery单还是没有效果.最终发现是<script>标签的放置问题.我是习惯的放置在<head>标签中,而且认为放置在哪效果都一样.但是<script>标签的出现会使整个页面脚本分析和运行而出现等待,而且只有在完全加载完成后,js

20160113 js中选择多个check一块删除

js中<script type="text/javascript"> $(document).ready(function (e) { $("#Button2").click(function () { if (confirm("确认要删除么!")) { var all = $(".xuanzhong"); var code = ""; for (var i = 0; i < all.le

vs 2012 调试不了js -- solution 中script document显示不出来

背景: 因为项目的需要,从ie8升级到ie11(并且自动更新安装了几个ie11的补丁),升级后想用vs2012 调试asp.net项目中的js 但是发现solution中script document项目没有在项目中运行时启动,js不能打断点(***的空心圈). 解决过程: 这个同组的同事以前遇到过,并且解决了,所以向他请教,无果,不知道怎么解决的... 搜索了一下不能打断点的提示信息,网上给的说法是高级设置ie中禁掉第三方的调试工具选项前面的勾去掉,无果:这个和我的问题没有关系. 之前有同事更

js中的script标签

在页面中用script标签引入javascript文件(<script type="text/javascript" src="js文件地址"></script>),浏览器在渲染页面的时候,当读取到script元素时,浏览器不会以HTML或XHTML的方式处理其内容,浏览器会通知浏览器的脚本引擎来接管script元素中的内容.   script元素的type属性定义脚本类型,type类型有: 1.text/ecmascript(表示以ECMA

JS中的运算符&amp;JS中的分支结构

一.JS中的运算符 1.算术运算(单目运算符) + 加.- 减.* 乘./ 除.% 取余.++ 自增.-- 自减 >>> +:有两种作用,连接字符串/加法运算.当+两边全为数字时,进行加法运算: 当+两边有任意一边为字符串时,起连接字符串的作用,连接之后的结果为字符串 除+外,其余符号运算时,会先尝试将左右变量用Number函数转为数字 >>> /: 结果会保留小数点 >>> ++: 自增运算符,将变量在原有基础上+1: --: 自减运算符,将变量在原

关于js中window.location.href,location.href,parent.location.href,top.location.href的用法

关于js中window.location.href,location.href,parent.location.href,top.location.href的用法 "window.location.href"."location.href"是本页面跳转. "parent.location.href" 是上一层页面跳转. "top.location.href" 是最外层的页面跳转. 举例说明: 如果A,B,C,D都是html,D

实例分析Vue.js中 computed和method不同机制

在vue.js中,有methods和computed两种方式来动态当作方法来用的 1.首先最明显的不同 就是调用的时候,methods要加上() 2.我们可以使用 methods 来替代 computed,效果上两个都是一样的,但是 computed 是基于它的依赖缓存,只有相关依赖发生改变时才会重新取值. 而使用 methods ,在重新渲染的时候,函数总会重新调用执行 为了方便理解,先上一段源码 <!DOCTYPE html> <html> <head> <m

js中三目运算符和&amp;&amp; || 符的个人浅见

这两天看到别人写的代码,感觉很牛逼,如下,大神请忽视 $(".lgn").on("click", function() { var a = {}; a.loginType = $(this).data("logintype"); a.loginType == wx_utils.LOGIN_TYPE.WX ? (a.username = $("#username").val(), a.password = $("#pa

MVC中处理Json和JS中处理Json对象

事实上,MVC中已经很好的封装了Json,让我们很方便的进行操作,而不像JS中那么复杂了. MVC中: public JsonResult Test() { JsonResult json = new JsonResult { Data = new { Name = "zzl", Sex = "male", } }; return Json(json); }   public JsonResult TestList() { List<User> user