专辑篇:JS高级

前言:本篇主要讲各个api主要方法及使用----还有就是js中与众不同的语言特性.


JavaScript对象

JS中创建对象的方式

创建直接的实例:

var person=new Object();
person.firstname="John";
person.lastname="Doe";
person.age=50;
person.eyecolor="blue"; 
document.write(person.firstname + " is " + person.age + " years old.");
-----------------------------------
替代语法
person={firstname:"John",lastname:"Doe",age:50,eyecolor:"blue"}
document.write(person.firstname + " is " + person.age + " years old.");

使用对象构造器





菜鸟教程(runoob.com)





备注:在javascript中this通常指向的是我们正在执行的函数本身,
或者是指向该函数所属的对象(运行时).

创建JavaScript对象实例:
一旦有了对象构造器,向已有对象添加新属性:

var myFather = new  person("John","Doe",50,"blue");
var myMother = new person("Sally","Rally",48,"green");

把属性添加到JavaScript对象

# 可以通过为对象赋值,向已有对象添加新属性:
# 假设personObj已存在,则可以为其添加新属性:firstname,lastname,age,eyecolor:
person.firstname="John";
person.lastname="Doe";
person.age=30;
person.eyecolor="blue";
x=person.firstname;

把方法添加到JavaScript对象

# 方法只不过是附加在对象上的函数.
# 在构造函数内部定义对象的方法
示例:
function person(firstname,lastname,age,eyecolor){
    this.firstname=firstname;
    this.lastname=lastname;
    this.age=age;
    this.eyecolor=eyecolor;
    this.changeName=changeName;
    function changeName(name){
        this.lastname=name;
    }
}
myMother=new person("Sally","Rally",48,"green");
myMother.changeName("Doe");

JavaScript类

JavaScript是面向对象的语言,但JavaScript不使用类.
在JavaScript中,不会创建类,也不会通过类来创建对象(这点和java/c++是完全不一样的).
JavaScript基于prototype,而不是基于类的.

JavaScript for in循环

JavaScriptfor...in语句循环遍历对象的属性

语法:
for(variable in object){
执行的代码...
}
注意:for...in循环中的代码块将针对每个属性执行一次

# 示例




菜鸟教程(runoob.com)

  

点击下面的按钮,循环遍历对象 "person" 的属性。


JS Number对象

JavaScript 数字

JavaScript只有一种数字类型.可以使用也可以不适用小数点来书写数字
表示方式:
var pi = 3.14;
var x = 34;
var y = 34e5;
var y = 34e-5;

# 所有javascript数字均为64位
JavaScript不是类型语言.与其他编程语言不同,JavaScript不定义,
不同类型的数字,比如整数,短,长,浮点等等.
在JavaScript中,数字不分为整数类型和浮点型类型,所有的数字都是由浮点
类型.
# 精度
整数最多为15位 (不使用小数点或指数计数法)
# 小数的运算不总是百分之百精确;
var x = 0.2+0.1;
# 8进制和16进制
如果前缀为0则JavaScript会把数值常量解释为8进制数,如果前缀为0和"x",则解
释为16进制数
#默认情况下,JavaScript数字为十进制显示.
但是你可以使用toString()方法输出16进制,8进制,2进制
var myNumber = 128;
myNumber.toString(16);   // 返回
80myNumber.toString(8);    // 返回 
200myNumber.toString(2);    // 返回 10000000

无穷大(Infinity)
var x = 2/0;正无穷 Infinity
var y = -2/0;负无穷-Infinity
NaN-非数字值

# NaN属性是代表非数字值的特殊值.该属性用于指示某个值不是数字.可以把Number对象设置为改制,来指示不是数字
可以使用isNaN()全局函数来判断一个值是否是NaN值
var x = 1000 / "Apple";
isNaN(x); // 返回 true
var y = 100 / "1000";
isNaN(y); // 返回 false
var x = 1000 / 0;
isNaN(x); // 返回 false

数字可以是数字或者对象

数字可以私有数据进行初始化,就像 x = 123;
JavaScript 数字对象初始化数据, var y = new Number(123);
# 实例
var x = 123;
var y = new Number(123);
typeof(x) // 返回 Number
typeof(y) // 返回 Object
# 实例
var x = 123;              
var y = new Number(123);
(x === y) // 为 false,因为 x 是一个数字,y 是一个对象

JavaScript字符串

  1. 字符串可以使用数组的形式取单个字符
  1. 字符串的长度属性length来计算字符串的长度
  2. indexOf()来查找子串在字符串中首次出现的位置,如果没有查到则返回-1,lastIndexOf()方法在字符串末尾开始查找子串出现的位置.
  3. 内容匹配:match()函数用来查找字符串中特定的字符,并且如果找到的话,则返回这个字符.如果没找到则返回null
  4. 替换内容,replace()方法在字符串中用某些字符替换另一些字符.
  5. 字符串大小写转换
    toUpperCase()/toLowerCase();
  6. 字符串转为数组:字符串使用split()函数转为数组:
txt="a,b,c,d,e"   // String
txt.split(",");   // 使用逗号分隔
txt.split(" ");   // 使用空格分隔
txt.split("|");   // 使用竖线分隔 
  1. 特殊字符,通过\转义

未完待续......

你可能感兴趣的:(专辑篇:JS高级)