函数和对象的创建以及面向对象的编程

  • 函数的创建方式:

① 函数声明

② 函数表达式

③ 使用Function类型的构造器创建

代码示例

 //01 函数声明
    function functionName() {
        console.log('以函数声明的方式来定义函数');
    }

    functionName();

    //02 函数表达式
    var func = function () {
        console.log('函数表达式的方式来定义函数');
    };
    func();

    //03 使用Function构造器来创建
    var funcName = new Function();
    funcName();
    //上面的代码等价于
    /*
    function funcName() {

    }
    */

关键字new的使用
可以使用new关键字来创建新的对象

———————————————————————————————————————

  • 可以使用new关键字来创建新的对象

  • 01 面向过程和面向对象编程

    • 1 面向对象编程和面向过程编程是一种编程思想,和具体的语言关系不大。

    • 02 面向过程编程和面向对象编程的主要区别

面向过程编程:
        关注点在于解决问题需要的每一个详细的步骤
        示例:
            自己洗衣服的过程
            ① 收集需要洗的脏衣服
            ② 准备洗衣粉、洗衣液等
            ③ 把衣服放到一个盆里
            ④ 接水
            ⑤ 把洗衣粉放到盆里
            ⑥ 摩擦,摩擦,不断的摩擦
            ⑦ 把洗好的衣服用清水冲洗干净
            ⑧ 尽量把把洗好的衣服的水分拧干
            ⑨ 晾晒
    面向对象编程:
        关注点在于解决问题需要的对象身上
        示例:
            使用洗衣机洗衣服的过程
            ① 收集需要洗的脏衣服
            ② 找到合适的洗衣机
            ③ 设定洗衣服和烘干的程序
  • 03 面向过程和面向对象他们的区别就类似于自己洗衣服和使用洗衣机洗衣服|自己做饭吃和去餐馆吃饭

  • 面向对象编程的相关概念

    • 01 对象
      • 什么是对象? 所有的一切都是对象,在开发中有一项重要的工作就是对象的划分
        一般来说,我们所指的对象是某个具体的事物,而非泛泛的类别
    • 02 对象的特征(静态描述信息)
      • 所谓特征就是一些特定的描述信息
        如:学生(性别、年龄、班级、专业、籍贯、家庭住址)
        如:汽车(颜色、车牌、品牌、价格等)
    • 03 对象的行为(动态特性)
      • 如:人(吃饭、睡觉、玩游戏、奔跑、运动等)
        如:狗(吃、睡、咬人、叫、流口水)
    • 04 js中的对象
      • 键-值对(key-value)的集合。
    • 05 现实生活中的对象和js对象的对应关系
      • 静态的描述信息 - js对象中的属性(属性就是定义在对象内部的变量)
        动态的行为特征 - js对象中的方法(方法就是定义在对象内部的函数)

** 06 代码示例:**

    var zhangsan = {
            name:"张三",
            sex:"男",
            age:18,
            address:"天上人间1号公馆",

            eat:function () {
                console.log('能吃');
            },
            sleep:function () {
                console.log("能睡");
            },
            say:function () {
                console.log("能说话");
            },
            run:function () {
                console.log("能运动");
            },
            song:function () {
                console.log("能唱歌");
            }
        };

        //打印对象的属性并调用相关的方法
        console.log(zhangsan.name,zhangsan.age,zhangsan.address);
        zhangsan.say();
        zhangsan.sleep();
```
_______________________________________________________________________

**为什么要使用面向对象编程?**
` *面向对象编程的优点: 更方便 + 提高代码的复用性*`
##### 典型的面向过程
```
<script>
    //01 创建标签
    var div = document.createElement("div");

    //02 设置样式
    div.style.width = "200px";
    div.style.height = "50px";
    div.style.backgroundColor = "red";

    //03 添加到页面上
    document.body.appendChild(div);
</script>
```

##### 面向对象的代码
```
<script>
   // $("body").append("<div>sdshdfskfsk</div>")
   $("body").append("<div style='height: 200px;width: 100px;border: 2px solid #2aa198'></div>");
</script>
```

**总结:面向对象编程其实是对面向过程的封装**
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 开篇废话是一种情怀 在我们开始学习面向对象之前,首先得先想一个问题,那就是何为对象? 在日常生活中我们有男朋友\女...
    西巴撸阅读 3,449评论 4 3
  • 工厂模式类似于现实生活中的工厂可以产生大量相似的商品,去做同样的事情,实现同样的效果;这时候需要使用工厂模式。简单...
    舟渔行舟阅读 12,396评论 2 17
  • 一、JavaScript基础知识回顾 1.1 JavaScript 1.1.1 javascript是什么? Ja...
    福尔摩鸡阅读 5,324评论 0 7
  • 单例模式 适用场景:可能会在场景中使用到对象,但只有一个实例,加载时并不主动创建,需要时才创建 最常见的单例模式,...
    Obeing阅读 6,542评论 1 10
  • 转载请著名出处 GitHub-TYRMars 文章Github地址 JavaScript基础知识剖析 01 01-...
    TYRMars阅读 3,666评论 0 7

友情链接更多精彩内容