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

  • 函数的创建方式:

① 函数声明

② 函数表达式

③ 使用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>
```

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

推荐阅读更多精彩内容

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