面向对象基础一之初体验使用面向对象进行开发

对 JS 中的面向对象的基础进行讲述, 初体验使用面向对象进行开发

主要内容是

  1. 面向对象的概念及特性
  2. 用面向对象的方式解决简单的标签创建实例

一些基础的概念

面向对象

面向对象的概念

  1. 面向对象就是使用对象
  2. 面向对象开发就是使用对象开发
  3. 面向过程就是以过程的方式开发
  4. 面向对象是面向过程的封装

面向对象的特性

  1. 抽象性

    如果需要用一对象来描述一个数据, 那就需要抽取这个对象的核心数据来描述

    • 抽取需要的核心属性和方法
    • 需要在特定情况下,才能明确对象的具体意义
  2. 封装性

    封装就是将数据和功能组合到一起

    • 在 js 中, 对象就是的集合

      • 键值如果是数据(基本数据, 复合数据, 空数据), 就称为属性
      • 键值如果是函数,就称为方法
    • 对象就是将属性和方法封装起来
    • 方法是将过程封装起来
  3. 继承性

    继承性就是自己没有, 别人有, 将别人的拿过来自己用, 并且成为自己的

    • 传统继承基于模板
    • js 的继承基于对象
      在 js 中的简单的继承模式: 混入模式(mix)
      在 jQuerty 中的混入叫做: extend

      var o1 = { name : 'Jhon' };
      var o2 = { age : 19 };
      function mix(o1,o2){
      for(var key in o2){
      o1[key] = o2[key];
      }
      }
      mix(o1, o2);

使用面向过程和面向对象进行标签创建

使用面向过程创建div, 并设置样式

  • 按部就班, 一步一步来
  • 只能一个一个添加属性
  • 如果创建多个div标签, 非常麻烦

    var div = document.createElement('div');
    documet.appendChild(div);
    div.style.width = '200px';
    div.style.height = '200px';
    div.style.backgroundColor = 'red';
    div.style.border = '10px dashed blue';
    ...

使用面向对象创建div, 并设置样式

  • 抽取对象(名词提炼): div, body
  • 分析属性和方法(动词提炼): appendChild, style

    function DivTag(){
    // 注意这里的 this 指的是 通过构造函数创建出来的实例对象
    this.DOM = document.createElement('div');
    appendTo : function(node){
    // this是实例对象, 不是DOM节点, 不能直接使用DOM属性和方法
    node.appendChild(this.DOM);
    };
    css : function(option){
    for(var key in option){
    this.DOM.style[key] = option[key];
    }
    }
    }
    var divTag = new DivTag();
    divTag.appendTo(document.body);
    divTag.css({
    width : '200px',
    height : 200px,
    backgroundColor : 'red',
    border : '10px dashed blue'
    });
  • 这样的使用对象的方式进行创建标签非常方便, 创建多个不同样式的标签也非常轻松
  • 但是这样也有缺点, 不能和 jQuery 一样, 不能进行链式变成, 我们可以这样修改, 在每一个方法后面加上一个return this

        function DivTag(){
    // 注意这里的 this 指的是 通过构造函数创建出来的实例对象
    this.DOM = document.createElement('div');
    appendTo : function(node){
    // this是实例对象, 不是DOM节点, 不能直接使用DOM属性和方法
    node.appendChild(this.DOM);
    return this;
    };
    css : function(option){
    for(var key in option){
    this.DOM.style[key] = option[key];
    }
    return this;
    }
    }
    var divTag1 = new DivTag()
    .appendTo(document.body)
    .css({
    width : '200px',
    height : 200px,
    backgroundColor : 'red',
    border : '10px dashed blue'
    });
    var divTag2 = new DivTag()
    .appendTo(document.body)
    .css({
    width : '400px',
    height : 400px,
    backgroundColor : 'pink',
    border : '10px dashed green'
    });

总结

什么是面向对象

面向对象说白了就是对面向过程进行了封装
比如说:
需求是 一个字符串是 str = 'abcdefg', 找到里面的e,并返回e的索引

  • 使用面向过程的处理办法就是, 遍历字符串, 得到索引

    var str = 'abcdefg';
    for(var i = 0;i < str.length;i++){
    var char = str.charAt(i);
    if(char == 'e'){
    conole.log(i);
    break;
    }
    }
  • 使用面向过程的处理办法就是, 使用indexOf, 得到索引

    var str = 'abcdefg';
    console.log(str.indexOf('e'));

    用生活中吃饭的的例子就可以这样理解:

  • 如果你自己烧, 那就需要(非常的麻烦, 时间有很长)
    1. 买菜
    2. 洗菜
    3. 烧饭烧菜
    4. 收拾
    5. 洗碗
  • 如果是上饭店, 那就非常简单(因为买菜, 洗菜, 烧饭烧菜, 洗碗的工作都是别人帮你完成了)
    1. 吃就行了

JS面向对象使用面向对象进行开发的更多相关文章

  1. python 全栈开发,Day52(关于DOM操作的相关案例,JS中的面向对象,定时器,BOM,client、offset、scroll系列)

    昨日作业讲解: 京东购物车 京东购物车效果: 实现原理: 用2个盒子,就可以完整效果. 先让上面的小盒子向下移动1px,此时就出现了压盖效果.小盒子设置z-index压盖大盒子,将小盒子的下边框去掉, ...

  2. 2018-2019-2 20175306实验二面向对象程序设计《Java开发环境的熟悉》实验报告

    2018-2019-2 20175306实验二面向对象程序设计<Java开发环境的熟悉>实验报告 面向对象程序设计-1 实验要求: 参考:> http://www.cnblogs.c ...

  3. Day046--JavaScript-- DOM操作, js中的面向对象, 定时

    一. DOM的操作(创建,追加,删除) parentNode 获取父级标签 nextElementSibling 获取下一个兄弟节点 children 获取所有的子标签 <!DOCTYPEhtm ...

  4. 2018-2019-20175205实验二面向对象程序设计《Java开发环境的熟悉》实验报告

    2018-2019-20175205实验二面向对象程序设计<Java开发环境的熟悉>实验报告 实验要求 没有Linux基础的同学建议先学习<Linux基础入门(新版)>< ...

  5. #2019-2020-4 实验二面向对象程序设计《Java开发环境的熟悉》实验报告

    2019-2020-4 实验二面向对象程序设计<Java开发环境的熟悉>实验报告 一.面向对象程序设计-1 ①实验要求: 1.参考 http://www.cnblogs.com/roced ...

  6. 前端 ---JS中的面向对象

    JS中的面向对象   创建对象的几种常用方式 1.使用Object或对象字面量创建对象 2.工厂模式创建对象 3.构造函数模式创建对象 4.原型模式创建对象 1.使用Object或对象字面量创建对象 ...

  7. 06-03 Java 面向对象思想概述、开发设计特征,类和对象的定义使用,对象内存图

    面向对象思想概述.开发设计特征 1:面向对象思想 面向对象是基于面向过程的编程思想. 面向过程:强调的是每一个功能的步骤 面向对象:强调的是对象,然后由对象去调用功能 2:面向对象的思想特点 A:是一 ...

  8. 前端JavaScript(3)-关于DOM操作的相关案例,JS中的面向对象、定时器、BOM、位置信息

    小例子: 京东购物车 京东购物车效果: 实现原理: 用2个盒子,就可以完整效果. 先让上面的小盒子向下移动1px,此时就出现了压盖效果.小盒子设置z-index压盖大盒子,将小盒子的下边框去掉,就可以 ...

  9. 轻松理解JS中的面向对象,顺便搞懂prototype和__proto__

    这篇文章主要讲一下JS中面向对象以及 __proto__,ptototype和construcator,这几个概念都是相关的,所以一起讲了. 在讲这个之前我们先来说说类,了解面向对象的朋友应该都知道, ...

随机推荐

  1. [JLOI2014] 松鼠的新家

    Description 松鼠的新家是一棵树,前几天刚刚装修了新家,新家有n个房间,并且有n-1根树枝连接,每个房间都可以相互到达,且俩个房间之间的路线都是唯一的.天哪,他居然真的住在"树&q ...

  2. [Luogu 1402] 酒店之王

    题目 Description XX酒店的老板想成为酒店之王,本着这种希望,第一步要将酒店变得人性化.由于很多来住店的旅客有自己喜好的房间色调.阳光等,也有自己所爱的菜,但是该酒店只有p间房间,一天只有 ...

  3. Day3--------------目录文件的浏览、管理及维护

    1.pwd命令功能 2.cd命令功能 cd..      返回上一级 cd~ cd- 返回上一次的目录 cd 3.ls命令功能 ls -a ls -all ls -l 4.cp命令功能 cp -i 覆 ...

  4. 漫谈Java IO之基础篇

    Java的网络编程如果不是专门搞服务器性能开发或者消息分发,几乎可能涉及不到.但是它却是面试找工作必问的一个知识点,涵盖的知识体系也非常广泛,从Java底层IO原理到操作系统内核组成,再到网络TCP. ...

  5. 测试驱动开发实践2————从testList开始

    内容指引 1.测试之前 2.改造dto层代码 3.改造dao层代码 4.改造service.impl层的list方法 5.通过testList驱动domain领域类的修改 一.测试之前 在" ...

  6. matlab: 数据的读写

    读取数据的方法 读取.txt数据 如果.txt是按照矩阵顺序保存的一个数组,可以用textread()函数来读取: GAP=textread('continua.txt'); 读取.fig图中的数据 ...

  7. Alpha冲刺——Day2

    一.合照 二.项目燃尽图 三.项目进展 图形界面基本完成 接口文档框架完成,接下来将会不断细化填充 登录界面向服务器请求数据进行ing 四.明日规划 1.注册登录接口能够完成 2.研究idea实现获得 ...

  8. Java作业-数据库

    本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结与数据库相关内容. 在Java中使用数据库要经过以下几个步骤: 1. 注册 JDBC 驱动 Class.forName("com ...

  9. router问题

    var http = require("http"); var router = require("./router.js"); //创建服务器 var ser ...

  10. java实现同步的两种方式

    同步是多线程中的重要概念.同步的使用可以保证在多线程运行的环境中,程序不会产生设计之外的错误结果.同步的实现方式有两种,同步方法和同步块,这两种方式都要用到synchronized关键字. 给一个方法 ...