JS高级笔记_javascript技巧
程序员文章站
2022-04-24 09:12:18
...
JS高级
一、JS的数据类型
1.基本类型
JS共有5大基本类型,分别是:
1)Undefined。他只有一个值:undefined。如果一个变量被定义但是没有给他赋值,那么这个时候系统会默认给这个变量赋值为undefined。
2)Null。它同样也只有一个值:null。他是一个引用类型,当一个准备保存对象的变量因为种种原因还没有指向一个对象的时候,可以给这个变量赋值为null,通常也是这么做的。
3)Number。数值类型,他是C#中的整型和浮点型的集合,它具体是什么类型还要看它被赋值的情况,一般来说赋值为什么类型他就为什么类型。另外注意 var num = 1.0;这个时候num是个整型,只有小数点后有确切的不为0的值的时候才是浮点型。关于Number类型还有一些其他知识点,如:NaN表示该值不是一个数字,isNaN()可以判断传入的值时候为Number类型;parseInt()可以将传入的参数转成数值类型,如果包含非数值类型字符串的话,会自动将字符串去掉,parseInt("123blue")的返回值为123,字符串blue部分被忽略,因此parseInt()方法可以理解为尝试把传入的参数转换成整型,转换不了的话会将转换不了的部分忽略。parseFloat()方法与parseInt()方法类似。
4)Boolean。布尔类型,类似C#中bool类型,有true和false两个取值,但是没有类似C#中0对应False,1对应true这样的与数字的对应关系。
5)String。字符串类型,保存的是0到16位的UNICODE代码组成的字符序列。
2.复杂类型
1)Object类型。是JS的*“父类”(因为JS中没有类的概念,说他是父类只是为了理解上的方便),是一组数据和方法(功能)的集合,但它不具备传统面向对象语言所支持的类和接口。Object类型本质是一个无序的键值对列表,类似于集合,json格式。它包含7个方法,分别是:
constructor() 构造函数?
hasOwnProperty(propertyName) 检查属性是否在当前对象中
isPrototypeOf(object) 检查对象是不是该对象原型
propertyIsEnumerable(propertyName) 检查属性是否能用for-in来循环
toString()
valueOf()
创建Object可以有多种方式:
通过new 关键字:var s = new Object(); s.name="james"; s.age=27;
通过JS的简单定义方式:var s = {}; s.name="james"; s.age=27;
对象字面量表示法:var s = {"name":"james","age":"27"};PS:json格式数据的key可以不用双引号括起来,value如果不是字符串的话也可以不用双引号括起来,但是推荐key和value都要用双引号括起来,以避免不必要的麻烦。
访问Object对象的属性的方法:
s.name 直接点出来。
s["name"];使用方括号(类似于索引器)的优点是可以通过变量来动态访问属性:var proName="name"; alert(s[proName]);
2)Array类型。是数据的有序列表
与其他数组的不同:
数组元素可以是任何类型,同一个数组的元素类型也可以不一样,相当于C#中的List
一、JS的数据类型
1.基本类型
JS共有5大基本类型,分别是:
1)Undefined。他只有一个值:undefined。如果一个变量被定义但是没有给他赋值,那么这个时候系统会默认给这个变量赋值为undefined。
2)Null。它同样也只有一个值:null。他是一个引用类型,当一个准备保存对象的变量因为种种原因还没有指向一个对象的时候,可以给这个变量赋值为null,通常也是这么做的。
3)Number。数值类型,他是C#中的整型和浮点型的集合,它具体是什么类型还要看它被赋值的情况,一般来说赋值为什么类型他就为什么类型。另外注意 var num = 1.0;这个时候num是个整型,只有小数点后有确切的不为0的值的时候才是浮点型。关于Number类型还有一些其他知识点,如:NaN表示该值不是一个数字,isNaN()可以判断传入的值时候为Number类型;parseInt()可以将传入的参数转成数值类型,如果包含非数值类型字符串的话,会自动将字符串去掉,parseInt("123blue")的返回值为123,字符串blue部分被忽略,因此parseInt()方法可以理解为尝试把传入的参数转换成整型,转换不了的话会将转换不了的部分忽略。parseFloat()方法与parseInt()方法类似。
4)Boolean。布尔类型,类似C#中bool类型,有true和false两个取值,但是没有类似C#中0对应False,1对应true这样的与数字的对应关系。
5)String。字符串类型,保存的是0到16位的UNICODE代码组成的字符序列。
2.复杂类型
1)Object类型。是JS的*“父类”(因为JS中没有类的概念,说他是父类只是为了理解上的方便),是一组数据和方法(功能)的集合,但它不具备传统面向对象语言所支持的类和接口。Object类型本质是一个无序的键值对列表,类似于集合,json格式。它包含7个方法,分别是:
constructor() 构造函数?
hasOwnProperty(propertyName) 检查属性是否在当前对象中
isPrototypeOf(object) 检查对象是不是该对象原型
propertyIsEnumerable(propertyName) 检查属性是否能用for-in来循环
toString()
valueOf()
创建Object可以有多种方式:
通过new 关键字:var s = new Object(); s.name="james"; s.age=27;
通过JS的简单定义方式:var s = {}; s.name="james"; s.age=27;
对象字面量表示法:var s = {"name":"james","age":"27"};PS:json格式数据的key可以不用双引号括起来,value如果不是字符串的话也可以不用双引号括起来,但是推荐key和value都要用双引号括起来,以避免不必要的麻烦。
访问Object对象的属性的方法:
s.name 直接点出来。
s["name"];使用方括号(类似于索引器)的优点是可以通过变量来动态访问属性:var proName="name"; alert(s[proName]);
2)Array类型。是数据的有序列表
与其他数组的不同:
数组元素可以是任何类型,同一个数组的元素类型也可以不一样,相当于C#中的List
推荐阅读
-
JavaScript的MVVM库Vue.js入门学习笔记
-
js经验分享 JavaScript反调试技巧
-
JavaScript中常用的简洁高级技巧总结
-
前端笔记之JavaScript面向对象(三)初识ES6&underscore.js&EChart.js&设计模式&贪吃蛇开发
-
javascript简写常用的12个技巧(可以大大减少你的js代码量)
-
javascript高级程序设计(第三版)学习笔记(一) 正则表达式整理
-
重温JavaScript中的正则表达式 js学习笔记
-
JS高级程序设计笔记
-
温习Android基础知识——《第一行代码(第三版)》读书笔记 Chapter 14 高级技巧
-
详解JS数组Reduce()方法详解及高级技巧