悟透Javascript undefined,null,"",0这四个值转换为逻辑值时就是false &this关键字
话题一:undefined,null,"",0这四个值转换为逻辑值时就是false
也就是在if判断时会把上面的五个作为false来判断。但是它们的类型确是不尽相同的,如下所示。
typeof(undefined) == 'undefined'
typeof(null) == 'object'
typeof("") == 'string'
typeof(0) == 'number'
typeof(false) == 'boolean'
下面是案例来说明,逻辑值为false的情况。
<script type="text/javascript">
function myFunc(){
if(!undefined){
alert("test1");
}
if(!null){
alert("test2");
}
if(!""){
alert("test3");
}
if(!0){
alert("test4");
}
if(!false){
alert("test5");
}
}
myFunc();
</script>
这些都会通过判断,因为它们都表示false。
另外再补充一下
"123" == 123 返回true
"123" === 123 返回false
三个等于号表示完全等,类型也要相等,前面的一二三表示字符串,后面的是数字。
话题二:Javascript中的函数与变量的关系?
javascript中,函数就是变量,函数体就是变量内容。
javascript执行引擎并非一行一行地分析和执行程序,而是一段一段地分析执行的。在同一段程序分析执行中,定义式的函数语句会被提取出来优先执行。
函数定义执行完之后,才会按照顺序执行其他语句代码。
案例一:
<script type="text/javascript">
function myfunc(){
alert("hello");
}
myfunc(); function myfunc(){
alert("yeah");
}
myfunc();
</script>
这段代码两次执行结果都是yeah,这就验证了刚才所说的了。前面的函数被后面覆盖了。
案例二:
<script type="text/javascript">
function myfunc(){
alert("hello");
}
myfunc();
</script>
<script type="text/javascript">
function myfunc(){
alert("yeah");
}
myfunc();
</script>
就会先执行hello,然后执行yeah了。因为分成两段,就一段一段执行了。这里要能去想象javascript解释器的工作机制。
案例三:
<script type="text/javascript">
function myfunc(){
alert("hello");
}
myfunc();
var myfunc = function(){
alert("yeah");
}
myfunc();
</script>
会先hello,然后yeah,为什么呢。因为第二个是定义变量的方式定义函数,不会优先执行。所以不会覆盖掉之前的函数。
话题三:javascript作用域?
var myName = "zhang";
就定义了window作用域的一个变量myName。
myName = "zhang";
就定义了window对象的一个属性myName。
两者几乎没有区别。对于全局的Javascript语句来说,加不加"var"都无所谓,但是对于一个函数体,就有区别了。
案例:
<script type="text/javascript">
var yourName = '王菲';//定义变量
myName = 'Jim';//定义属性
alert(myName+" like "+yourName);//输出"Jim like 王菲"
ChangeNames();
function ChangeNames(){
alert("Your old name is "+yourName);//输出"Your old name is undefined"
alert("My old name is "+myName);//输出"My old name is Jim"
var yourName = "李亚鹏";
myName = "JiQing";
alert(myName+" like "+yourName);//输出"JiQing like 李亚鹏"
}
alert(myName+" like "+yourName);//输出"JiQing like 王菲"
</script>
这里面可以看出,定义成var的格式,函数里的yourName与函数外的yourName没有关系。
而没有定义成var的格式,函数里的变量和外的是相关联的,是一个东西,里面变化了,外面也收到影响。
比如myName。
当代码运行进入一个函数时,Javascript会创建一个新的作用域。变量名最好加个"var",这样作用域不容易产生混淆。
话题四:函数和对象
1.任何一个函数都可以为其动态地添加或去除属性。函数具有对象性。
案例:
<script type="text/javascript">
function Sing(){
alert(Sing.author+" : "+Sing.poem);
}
Sing.author = "李白";
Sing.poem = "汉家秦地月,流影照明妃。一上玉关道,天涯去不归。";
Sing();//输出"李白:汉家秦地月,流影照明妃。一上玉关道,天涯去不归。"
Sing.author = "李战";
Sing.poem = "日出汉家天,月落阴山前。女儿琵琶怨,已唱三千年。";
Sing();//输出"李战:日出汉家天,月落阴山前。女儿琵琶怨,已唱三千年。"
</script>
2.对象和函数的波粒二象性,即有数组的特点又有对象属性的特点
案例:
<script type="text/javascript">
var anObject = {};
anObject.aProperty = "Property of object";
anObject.aMethod = function(){
alert("Method of object");
}
alert(anObject["aProperty"]);//输出"Property of object"
anObject["aMethod"]();//输出"Method of object"
alert(anObject.aProperty);//输出"Property of object"
anObject.aMethod();//输出"Method of object"
</script>
既可以以数组的方式输出,又可以以对象属性的方式输出。
话题五:this关键字
在Javascript函数中,你只能把this看成当前服务的"这个"对象。
<script type="text/javascript">
function WhoAmI(){
alert("I'm "+this.name+" of "+typeof(this));
}
WhoAmI();//this是window
var BillGates = {name:"Bill Gates"};
BillGates.WhoAmI = WhoAmI;//将函数WhoAmI作为BillGates的方法
BillGates.WhoAmI();//this是BillGates var SteveJobs = {name:"SteveJobs"};
SteveJobs.WhoAmI = WhoAmI;
SteveJobs.WhoAmI();//this是SteveJobs WhoAmI.call(BillGates);//直接将BillGates作为this,调用WhoAmI
WhoAmI.call(SteveJobs);//直接将SteveJobs作为this,调用WhoAmI BillGates.WhoAmI.call(SteveJobs);//this是SteveJobs,调用BillGates的WhoAmI方法
SteveJobs.WhoAmI.call(BillGates);//this是BillGates,调用SteveJobs的WhoAmI方法 WhoAmI.WhoAmI = WhoAmI;//将函数WhoAmI作为WhoAmI的方法
WhoAmI.name = "WhoAmI";
WhoAmI.WhoAmI();
</script>
悟透Javascript undefined,null,"",0这四个值转换为逻辑值时就是false &this关键字的更多相关文章
- 悟透javascript读书笔记
1.undefined,null,0,"" 这四个值转换为逻辑值时是false,其他无论简单类型值,对象或者函数转换过来都是true 2.如图 第一个是“声明了一个变量,给变量赋 ...
- Javascript代码执行过程-《悟透Javascript》笔记
本文摘录自李战老师<悟透Javascript>一书的部分章节,为适应博客发表作了一点点修改. 1) 预编译分析. JavaScript执行引擎将所有定义式函数直接创建为作用域上的函数变量, ...
- javascript中的undefined,null,"",0和false的云集
在各种各样的数据类型中,我们都会为其定义一个"空值"或"假值",比如对象类型的空值null,.NET Framework中数据库字段的空值DBNull,bool ...
- (转载)悟透JavaScript
引子 编程世界里只存在两种基本元素,一个是数据,一个是代码.编程世界就是在数据和代码千丝万缕的纠缠中呈现出无限的生机和活力. 数据天生就是文静的,总想保持自己固有的本色:而代码却天生活泼,总想改变这个 ...
- 悟透JavaScript
要理解JavaScript,你得首先放下对象和类的概念,回到数据和代码的本原.前面说过,编程世界只有数据和代码两种基本元素,而这两种元素又有着纠缠不清的关系.JavaScript就是把数据和代码都简化 ...
- 悟透JavaScript(理解JS面向对象的好文章)
引子 编程世界里只存在两种基本元素,一个是数据,一个是代码.编程世界就是在数据和代码千丝万缕的纠缠中呈现出无限的生机和活力. 数据天生就是文静的,总想保持自己固有的本色:而代码却天生活泼,总想改变这个 ...
- 悟透JavaScript (一)
首先说明,这是别人写的一篇文章,写得很好,对理解JavaScript很有好处,所以转帖过来. 引子 编程世界里只存在两种基本元素,一个是数据,一个是代码.编程世界就是在数据和代码千丝万缕的纠缠中 ...
- 区分JS中的undefined,null,"",0和false
在程序语言中定义的各种各样的数据类型中,我们都会为其定义一个"空值"或"假值",比如对象类型的空值null,.NET Framework中数据库 字段的空值DB ...
- 悟透JavaScript(二)
初看原型 prototype源自法语,软件界的标准翻译为“原型”,代表事物的初始形态,也含有模型和样板的意义.JavaScript中的prototype概念恰如其分地反映了这个词的内含,我们不能将其理 ...
随机推荐
- python 面向对象深入理解
面向过程 函数式编程 面向对象编程:面向对象是由类和对象组成,只要用类和对象实现的,就是面向对象编程 def Bar(): print "This is Bar " ...
- 二分图的判定hihocoder1121 and hdu3478
这两个题目都是二分图的判定,用dfs染色比较容易写. 算法流程: 选取一个没有染色的点,然后将这个点染色,那么跟他相连的所有点一定是不同颜色的,所以,如果存在已经染过颜色的,如果和这个颜色相同的话,就 ...
- SAMBA用户访问指定的目录
指定某个用户访问一个特定的共享文件夹sfx 用户可以访问abc目录 别的用户不可以访问abc目录 先创建一个用户命令useradd sfx 创建一个smbpasswd用户 在创建这个用户时要先创建一个 ...
- javascript中强制类型转换
javascript开发过程中,强制类型转换一般发生在条件判断和==运算符.其他情况,发生的类型转换(与这两种情况也是基本类似,属于万变不离其宗的范畴),暂不讨论. == 双等运算符 考虑代码: a ...
- HTML+CSS基础学习笔记(4)
一.认识CSS样式 1.定义 CSS全称:层叠样式表(Cascading Style Sheets) 主要作用:定义HTML内容在浏览器内的显示样式,比如文字大小.颜色.字体加粗等 优点:通过定义某个 ...
- 前后端分离--构建前端Mock Server--windows部署rap
mock:模拟的,虚假的 mock server:模拟服务,模拟请求,模拟虚假数据 为了前后端更好的分工,接口文档是必须的,前后端都根据接口文档写代码,然后对接接口就行了. 但是,后端跟不上前端节奏, ...
- (转)Spring读书笔记-----Spring核心机制:依赖注入
Java应用(从applets的小范围到全套n层服务端企业应用)是一种典型的依赖型应用,它就是由一些互相适当地协作的对象构成的.因此,我们说这些对象间存在依赖关系.加入A组件调用了B组件的方法,我们就 ...
- MES项目中出现的一个事务嵌套的使用场景
昨天在MES项目中,需要在业务逻辑的几个关键点记录错误信息,需要把错误信息写入数据表. 但是由于整个业务逻辑都是包在一个事务模板里面的 比如这样的: WhhTransactionTemplate tr ...
- javascript类继承系列二(原型链)
原型链是采用最主要的继承方式,原理:每一个类(构造器,js中的function)都有一个原型属性(prototype)指向一个原型对象,原型对象有一个构造器(constructor),它又指回到fun ...
- window.event对象详细介绍
1.event代表事件的状态,例如触发event对象的元素.鼠标的位置及状态.按下的键等等.event对象只在事件发生的过程中才有效.event的某些属性只对特定的事件有意义.比如,fromEleme ...