本文主要是介绍javascript高手必经之路(二),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1.深入理解变量作用域:每个javascript执行环境都有一个和它关联在一起的作用域链,这个作用于连是一个对象列表或者对象链,当javascript代码需要查询变量x的值时(一个成为变量名解析的过程),它就开始查看该链的第一个对象,如果那个对象有一个名为x的属性,那么就采用那个属性的值,如果第一个对象没有名为x的属性,javascript就会继续查询链中的第二个对象,依次查询下去。javascript的顶层代码中(不属于任何函数定义的代码),作用域只由一个对象构成,那就是全局对象,所有变量都是在这一个对象中查询的,在一个飞嵌套的函数中,作用域是由两个对象构成的,第一个是函数的调用对象,第二个就是全局对象,当然,在一个嵌套函数的作用域中可以有三个或者更多的对象,注意,在一个页面中的不同javascript代码段其实可以合并。例如下面的例子
<script type="text/javascript">
<!--
var global = "global";
//-->
</script>
<script type="text/javascript">
<!--
alert(global);//这里可以输出global信息
//-->
</script>
2.在javascript中 var po = "1"*"2";也是可以起效果的,在进行*的时候,javascript首先将“1”和“2”转换成数字
alert("2"*"3");相当于alert(2*3);
alert("1"-1);相当于alert(1-1);
var b = "1";alert(++b);这样也是起效果的
alert("1"++);不起效果
3.==比较符与===比较符,前者表示通过类型转换后是相等就可以返回true,而后者的限制条件更强,要求数据类型也必须一样,废话少说,上代码
<script type="text/javascript">
<!--
var a = "1";
alert(a===1);//返回false
alert(a==="1");//返回true
alert(a==1);//返回true
alert(a=="1");//返回true
//-->
</script>、
另外,对于===运算符,如果两个都是null,或undefined,返回true,只要有一个是NaN,就返回false
所以,即使两者的类型不同,仍然可能返回true
alert("1"==true);//返回true,==两边都被转换成了数字1,所以相等
!= 与!==刚好相反
<script type="text/javascript">
<!--
var global = "global";
//-->
</script>
<script type="text/javascript">
<!--
alert(global);//这里可以输出global信息
//-->
</script>
2.在javascript中 var po = "1"*"2";也是可以起效果的,在进行*的时候,javascript首先将“1”和“2”转换成数字
alert("2"*"3");相当于alert(2*3);
alert("1"-1);相当于alert(1-1);
var b = "1";alert(++b);这样也是起效果的
alert("1"++);不起效果
3.==比较符与===比较符,前者表示通过类型转换后是相等就可以返回true,而后者的限制条件更强,要求数据类型也必须一样,废话少说,上代码
<script type="text/javascript">
<!--
var a = "1";
alert(a===1);//返回false
alert(a==="1");//返回true
alert(a==1);//返回true
alert(a=="1");//返回true
//-->
</script>、
另外,对于===运算符,如果两个都是null,或undefined,返回true,只要有一个是NaN,就返回false
所以,即使两者的类型不同,仍然可能返回true
alert("1"==true);//返回true,==两边都被转换成了数字1,所以相等
!= 与!==刚好相反
这篇关于javascript高手必经之路(二)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!