JavaScript面向对象前置知识

1、JS的组成

ECMAScript、DOM、BOM

2、JS基本数据类型和复杂数据类型

基本数据类型

  • string
  • number
  • boolean
  • null
  • undefined
    复杂数据类型
  • object

区别

  1. 存储方式不同
  • 基本数据类型的变量在栈区中直接保存变量的值
  • 复杂数据类型的变量在栈区中保存地址,该地址指示其“真身”在堆区中的位置
  1. 操作方式不同
  • 基本数据类型的变量名操作变量的值
  • 复杂数据类型的变量名操作变量的地址

3、JS数据类型的获取和判断

1.获取数据类型

typeof 变量
  1. 判断数据类型
  • 使用typeof,复杂数据类型永远返回object
typeof 变量 == 数据类型
console.log(typeof undefined);  // undefined
console.log(typeof null);  // Object
  • 使用instanceof,只要是其类或其父类均返回true
变量 instanceof 数据类型

4、JS的=和==和===

  • = 赋值
  • == 值比较(自动类型转换)
  • === 值比较和对象类型比较
console.log(123 == '123');  // true
console.log(123 === '123');  // false

5、JS中的函数

5.1、创建方式

  1. 声明函数
    该形式可用于类的创建
function 函数名称 (形参列表)
{
    函数体
}
  1. 函数表达式
// 匿名函数(常用)
var func01 = function () {

}
// 命名的函数表达式(不常用)
var func02 = function func () {

} 
  1. 使用构造函数创建函数对象
    Function是一个构造器,function是Function实例化的一个对象
var func02 = new Function("console.log('demo');");

在 JavaScript 中,用 new 关键字来调用的函数,称为构造函数。
https://blog.csdn.net/sinat_21742529/article/details/83659459

js 里面的 function 与 Function
https://www.jianshu.com/p/0480860f8987

js里Function 与 function 一样吗
https://zhidao.baidu.com/question/1498968439326505379.html

5.2、函数使用技巧

  1. arguments
<script>
    function func(name, age) {
        for(var i=0; i<arguments.length; i++){
            console.log(arguments[i]);
        }
    }
    func('David');  // David
    func('David', 20);  // David 20
    func('David', 20, '男');  // David 20 男
</script>

突然想到foreach的知识点,记录一下

js中的foreach用法
https://blog.csdn.net/fanfan_h/article/details/91406310

  1. length属性和name属性
  • length属性返回形参的个数
  • name属性返回函数名
function func(name, age) {}
console.log(func.length);  // 2
console.log(func.name);  // func
  1. 函数重载
    js没有函数重载,同名函数后面的会覆盖前面的
function sum(a, b) {return a+b;}
function sum(a, b, c) {return a+b+c;}
console.log(sum(1, 2));  // NaN
console.log(sum(1, 2, 3));  // 6

但是可以通过arguments个数来模拟重载

<script>
    function sum() {
        if(arguments.length === 2){
            return arguments[0] + arguments[1];
        }else if(arguments.length === 3){
            return arguments[0] + arguments[1] + arguments[2];
        }else{
            return NaN;
        }
    }
    console.log(sum(1, 2));  // 3
    console.log(sum(1, 2, 3));  // 6
</script>

5.3、函数的几种叫法

  1. 命名函数、匿名函数
  2. 闭包
  • 函数内部还有函数
  • 内部函数引用外部函数的变量
  1. 静态方法、实例方法

6、JS的作用域

  1. js中的作用域
  • script标签构成的全局作用域
  • 在js中函数是唯一一个可以创建局部作用域的对象
    注:js中一对{}内部不算一个局部作用域
  1. 作用域链
    函数内部还可以声明函数,形成作用域链
<script>
    function func1() {
        var a = 1;
        var b = 2;
        function func2() {
            var a = 100;
            console.log('a=' + a + ', b=' + b);
        }
        func2();
    }
    func1();  // a=100, b=2
</script>

7、JS变量和函数提升

执行顺序

  1. 把变量的声明提升到当前作用域的最前面
  2. 把函数声明提升到当前作用域前面
  3. 执行赋值、运算
  4. 最后执行回调函数,如定时器、监听

js执行顺序详解
https://blog.csdn.net/yournevermore/article/details/86436245

8、JS异常处理

抛出异常throw
捕捉异常try-catch-finally

<script>
    function divide(a, b) {
        if(b === 0)
            throw '分母不能为零';
        else
            console.log(a / b);
    }

    try{
        divide(10, 0)
    }catch (e) {
        console.log('执行了catch');
    }finally {
        console.log('执行了finally');
    }
    // 执行了catch
    // 执行了finally'

    divide(10, 0);  // 抛出自定义异常
    console.log('看看有没有执行到这里');  // 被前面的异常截止,没有执行这句话
</script>

9、DOM操作

增删改查

  1. 增加
var newDiv = document.createElement('div');
父结点.appendChild(newDiv);  // 添加到最后
父结点.insertBefore(要插入的结点, 哪个结点的前面)
  1. 删除
结点.remove()
父结点.removeChild(子结点)
结点.innerHTML = ...
结点.style = ...
结点.setAttribute(指定属性, 指定值)
document.getElementById();
document.getElementByClass();
document.getElementByTagName();
document.getElementByName();

10、BOM操作

  1. 全局作用域
    全局作用域中的变量或者函数都会变成window的属性或者方法
  2. 改变窗口位置
moveTo
moveBy
  1. 改变窗口大小
resizeTo
resizeBy
  1. 间歇调用和超时调用
setInterval
setTimeout
<script>
    var timeoutFunc = function () {
        console.log("setTimeout时间到");
    };
    var intervalFunc = function () {
        console.log("setInterval时间到")
    };

    var timer1 = setTimeout(timeoutFunc, 1000);
    var timer2 = setInterval(intervalFunc, 2000);

    window.clearTimeout(timer1);
    window.clearInterval(timer2);
</script>

js定时器的清除
https://www.cnblogs.com/Dream2hc/p/web23863.html

js各种位置相关属性
https://www.jianshu.com/p/fffa7a8efb22
https://www.cnblogs.com/zhipeng007/p/10614651.html

11、创建对象的方式

  1. 字面量的方式创建对象
var p1 = {
    name: '张三',
    age: 20,
    gender: '男',
    run: function() {
        console.log(this.name + '会跑');
    }
}
  1. 内置构造函数的方式创建对象
var p1 = new Object()
p1.name = '张三';
p1.age = 20;
p1.gender = '男';
p1.run = function() {
    console.log(this.name + '会跑');
}
  1. 简单工厂函数的方式类创建对象
function createPerson(name, age, gender) {
    var p = new Object();
    p.name = name;
    p.age = age;
    p.gender = gender;
    p.run = function() {
        console.log("this.name + '会跑'");
    }
    return p;
}
var UJ = createPerson("David", 20, "男");
var Jenny = createPerson("Jenny", 19, "女");
console.log(UJ === Jenny);  // 不是同一个对象
  1. 自定义构造函数创建对象
    这是js中“类”的创建最常用的方式
function Person(name, age, gender) {
    var this = new Object();  // 自动执行,创建一个空对象,this指向新对象

    this.name = name;
    this.age = age;
    this.gender = gender;

    return this;  // 自动执行,向外界返回这个新对象
}
var p = new Person('David', 20, '男');

省去自动执行的代码,即

function Person(name, age, gender) {
    this.name = name;
    this.age = age;
    this.gender = gender;
}
var p = new Person('David', 20, '男');

12、对象的改进

  1. 使用json传递参数
function Person(options) {
    this.name = options.name;
    this.age = options.age;
    this.gender = options.gender;

    this.eat = function(something) {
        console.log(this.name + '正在吃' + something);
    }
    this.runTo = function(somewhere) {
        console.log(this.name + '正跑去' + somewhere);
    }
}
var p = new Person({name: 'David', age: 18, gender: '男'});
  1. 使用函数的原型
function Person(options) {
    this.name = options.name;
    this.age = options.age;
    this.gender = options.gender;
}

Person.prototype.eat = function(something) {
    console.log(this.name + '正在吃' + something);
};
Person.prototype.run = function(somewhere) {
    console.log(this.name + '正跑去' + somewhere);
};

var p1 = new Person({name: 'David', age: 20, gender: '男'});
var p2 = new Person({name: 'Jenny', age: 19, gender: '男'});
console.log(p1.eat === p2.eat);  // 相同方法共享同一片内存空间
  1. 使用函数的原型进一步封装
function Person(options) {
    this._init(options);
}

Person.prototype = {
    _init: function(options) {
        this.name = options.name;
        this.age = options.age;
        this.gender = options.gender;
    }
    eat: function(something) {
        console.log(this.name + '正在吃' + something);
    },
    run: function(somewhere) {
        console.log(this.name + '正跑去' + somewhere);
    }
}

var p1 = new Person({name: 'David', age: 20, gender: '男'});
var p2 = new Person({name: 'Jenny', age: 19, gender: '男'});
console.log(p1.eat === p2.eat);  // 相同方法共享同一片内存空间
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,591评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,448评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,823评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,204评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,228评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,190评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,078评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,923评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,334评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,550评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,727评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,428评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,022评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,672评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,826评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,734评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,619评论 2 354

推荐阅读更多精彩内容