详细介绍JS两种语法使用说明

后面跟任意的表达式,JS两种语法有明显不同。匹配时会先计算case后面的表达式再匹配。匹配时用的是 === 符号,而不是 == 符号,所以匹配过程不允许任何类型转换,default 放在最后只是逻辑上的需求,而它可以放在 switch 内的任何地方。

 
 
  1. var x = 1;  
  2.         switch (x + 1) {  
  3.             case '2':  
  4.                 alert('string:2');  
  5.                 break;  
  6.             default:  
  7.                 alert('default');  
  8.                 break;  
  9.             case 1 + 1:  
  10.                 alert('number:2');  
  11.                 break;  
  12.         }  
  13.         // result:  
  14.         // 'number:2' 

语法:for(variable in object)
其中 variable  允许任意的表达式,只要计算结果能作为赋值表达式的左侧,迭代对象属性名时并不保证任何特殊的迭代顺序,它也只迭代用户自定义的属性,而预定义的属性和方法是不会迭代的(比如:Math 的 cos 属性)数组本身是一种特殊的对象,当JS两种语法应用于数组时,迭代的是数组的索引。

 
 
  1. // 将对象 obj 的属性名复制到数组中  
  2.         var obj =  
  3.         {  
  4.             x: 1,  
  5.             y: new Date(),  
  6.             z: function() { }  
  7.         }  
  8.         var arr = new Array();  
  9.         var i = 0;  
  10.         for (arr[i++] in obj);  
  11.         alert(arr[0]);// 'x'  
  12.         alert(arr[1]);// 'y'  
  13.         alert(arr[2]);// 'z' 

当解析器遇到方法定义时,解析器对其进行解析并存储在一个以方法名命名的对象属性中。JS两种语法当这个方法是内嵌在其他方法中时,这个属性是 call 对象的属性(每个方法里都有一个call对象。

 
 
  1. var i = 1;  
  2.        single:  
  3.        {  
  4.            if (i == 1)  
  5.                break single;  
  6.            i++;  
  7.        }  
  8.        alert(i);  
  9.        out:  
  10.        while (i == 1 || i == 3) {  
  11.            while (true) {  
  12.                i++;  
  13.                alert(i);  
  14.                if (i == 2) {  
  15.                    continue;  
  16.                }  
  17.                else {  
  18.                    continue out;  
  19.                }  
  20.            }  
  21.            i++;  
  22.            alert(i);  
  23.        }  
  24.        alert(i);  
  25.        // result: 

而方法里的局部变量或内嵌方法均存储于此对象属性中),JS两种语法否则是全局对象的属性,方法和变量是在不同时间被解析定义的,方法是在解析的时候被定义的,而变量是在运行的时候被定义的。

网页标题:详细介绍JS两种语法使用说明
网页URL:http://www.shufengxianlan.com/qtweb/news45/362595.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联