分享人:吴泽华
目录
1.背景介绍
2.知识剖析
3.常见问题
4.解决方案
5.编码实战
6.扩展思考
7.参考文献
8.更多讨论
ECMAScript是JavaScript在语法和语义上的标准、规范。JavaScript是基于ECMAScript标准实现的。 Javascript包括ECMAScript、DOM、BOM。 在日常场合,这两个词是可以互换的。
在 ECMAScript 规范中,共定义了 7 种数据类型,
任何方法都无法改变一个基本类型的值,比如一个字符串:
var name = "mary";
name.toUpperCase(); //"MARY"
console.log(name); //"mary"
var person = "mary";
person.age = 22;
person.method = function () {
return 100;
};
console.log(person.age);//undefined
console.log(person.method);//提示错误
第一个例子:会发现原始的name并未发生改变,而是调用了toUpperCase()方法后返回的是一个新的字符串。
第二个例子:我们不能给基本类型添加属性和方法。
我们可为引用类型添加属性和方法,也可以删除其属性和方法
var person = {};
person.name = 'jozo';
person.age = 22;
person.sayName = function(){console.log(person.name);}
person.sayName();// 'jozo'
delete person.name; //删除person对象的name属性
person.sayName(); // undefined
上面代码说明引用类型可以拥有属性和方法,并且是可以动态改变的。
假如有以下几个基本类型的变量:
var name = 'jozo';
var city = 'guangzhou';
var age = 22;
var person1 = {name:'jozo'};
var person2 = {name:'xiaom'};
var person3 = {name:'xiaoq'};
只有在它们的值相等的时候它们才相等。
var a = 1;
var b = true;
console.log(a == b);//true
在用==比较两个不同类型的变量时会进行一些类型转换。像上面的比较先会把true 转换为数字1再和数字1进行比较,结果就是true了。
var person1 = {};
var person2 = {};
console.log(person1 == person2); // false
引用类型是按引用访问的,换句话说就是比较两个对象的堆内存中的地址是否相同,那很明显, person1和person2在堆内存中地址是不同的
function addTen(num){
num+=10;
return num;
}
var count=20;
var result=addTen(count);
console.log(count);
console.log(result);
function setName(obj){
obj.name="LSN";
}
var person=new Object();
setName(person);
console.log(person.name);//LSN
答:Typeof操作符是检测基本类型的最佳工具
var num = 1;
var a = 'a';
var b;
var flag = true;
var c = null;
alert(typeof num); //number
alert(typeof a); //string
alert(typeof b); //undefined
alert(typeof flag); //boolean
alert(typeof c); //object
instanceof :判断是否是某个引用类型。
var a = [1,2,3];
alert(a instanceof Object); //true
alert(a instanceof Array); //true
alert(a instanceof RegExp); //false
感谢大家观看
BY : 吴泽华