JS面向对象使用面向对象进行开发
面向对象基础一之初体验使用面向对象进行开发
对 JS 中的面向对象的基础进行讲述, 初体验使用面向对象进行开发
主要内容是
- 面向对象的概念及特性
- 用面向对象的方式解决简单的标签创建实例
一些基础的概念
面向对象
面向对象的概念
- 面向对象就是使用对象
- 面向对象开发就是使用对象开发
- 面向过程就是以过程的方式开发
- 面向对象是面向过程的封装
面向对象的特性
抽象性
如果需要用一对象来描述一个数据, 那就需要抽取这个对象的核心数据来描述
- 抽取需要的核心属性和方法
- 需要在特定情况下,才能明确对象的具体意义
封装性
封装就是将数据和功能组合到一起
- 在 js 中, 对象就是键和值的集合
- 键值如果是数据(基本数据, 复合数据, 空数据), 就称为属性
- 键值如果是函数,就称为方法
- 对象就是将属性和方法封装起来
- 方法是将过程封装起来
- 在 js 中, 对象就是键和值的集合
继承性
继承性就是自己没有, 别人有, 将别人的拿过来自己用, 并且成为自己的
- 传统继承基于模板
js 的继承基于对象
在 js 中的简单的继承模式: 混入模式(mix)
在 jQuerty 中的混入叫做: extendvar 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 thisfunction 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'));用生活中吃饭的的例子就可以这样理解:
- 如果你自己烧, 那就需要(非常的麻烦, 时间有很长)
- 买菜
- 洗菜
- 烧饭烧菜
- 收拾
- 洗碗
- 如果是上饭店, 那就非常简单(因为买菜, 洗菜, 烧饭烧菜, 洗碗的工作都是别人帮你完成了)
- 吃就行了
JS面向对象使用面向对象进行开发的更多相关文章
- python 全栈开发,Day52(关于DOM操作的相关案例,JS中的面向对象,定时器,BOM,client、offset、scroll系列)
昨日作业讲解: 京东购物车 京东购物车效果: 实现原理: 用2个盒子,就可以完整效果. 先让上面的小盒子向下移动1px,此时就出现了压盖效果.小盒子设置z-index压盖大盒子,将小盒子的下边框去掉, ...
- 2018-2019-2 20175306实验二面向对象程序设计《Java开发环境的熟悉》实验报告
2018-2019-2 20175306实验二面向对象程序设计<Java开发环境的熟悉>实验报告 面向对象程序设计-1 实验要求: 参考:> http://www.cnblogs.c ...
- Day046--JavaScript-- DOM操作, js中的面向对象, 定时
一. DOM的操作(创建,追加,删除) parentNode 获取父级标签 nextElementSibling 获取下一个兄弟节点 children 获取所有的子标签 <!DOCTYPEhtm ...
- 2018-2019-20175205实验二面向对象程序设计《Java开发环境的熟悉》实验报告
2018-2019-20175205实验二面向对象程序设计<Java开发环境的熟悉>实验报告 实验要求 没有Linux基础的同学建议先学习<Linux基础入门(新版)>< ...
- #2019-2020-4 实验二面向对象程序设计《Java开发环境的熟悉》实验报告
2019-2020-4 实验二面向对象程序设计<Java开发环境的熟悉>实验报告 一.面向对象程序设计-1 ①实验要求: 1.参考 http://www.cnblogs.com/roced ...
- 前端 ---JS中的面向对象
JS中的面向对象 创建对象的几种常用方式 1.使用Object或对象字面量创建对象 2.工厂模式创建对象 3.构造函数模式创建对象 4.原型模式创建对象 1.使用Object或对象字面量创建对象 ...
- 06-03 Java 面向对象思想概述、开发设计特征,类和对象的定义使用,对象内存图
面向对象思想概述.开发设计特征 1:面向对象思想 面向对象是基于面向过程的编程思想. 面向过程:强调的是每一个功能的步骤 面向对象:强调的是对象,然后由对象去调用功能 2:面向对象的思想特点 A:是一 ...
- 前端JavaScript(3)-关于DOM操作的相关案例,JS中的面向对象、定时器、BOM、位置信息
小例子: 京东购物车 京东购物车效果: 实现原理: 用2个盒子,就可以完整效果. 先让上面的小盒子向下移动1px,此时就出现了压盖效果.小盒子设置z-index压盖大盒子,将小盒子的下边框去掉,就可以 ...
- 轻松理解JS中的面向对象,顺便搞懂prototype和__proto__
这篇文章主要讲一下JS中面向对象以及 __proto__,ptototype和construcator,这几个概念都是相关的,所以一起讲了. 在讲这个之前我们先来说说类,了解面向对象的朋友应该都知道, ...
随机推荐
- [译文] SQL JOIN,你想知道的应该都有
介绍 这是一篇阐述SQL JOINs的文章. 背景 我是个不喜欢抽象的人,一图胜千言.我在网上查找了所有的关于SQL JOIN的解释,但是没有找到一篇能用图像形象描述的. 有些是有图片的但是他们没有覆 ...
- 数据库 --> MySQL使用
MySQL使用 代码: #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h>#includ ...
- Java高级特性之枚举
在Java SE5之前,我们要使用枚举类型时,通常会使用static final 定义一组int常量来标识,代码如下 public static final int MAN = 0; public s ...
- 阿里聚安全·安全周刊】一种秘密窃取数据的新型 Android 木马|iOS 11相机惊现BUG
本周的七个关键词: 新型 Android 木马丨 TLS 1.3 丨 阿里安全图灵实验室 丨 漏洞感染 Linux 服务器 丨 CPU曝极危漏洞 丨 iOS 11相机BUG 丨R2D2技术 - ...
- APP案例分析
产品 蓝叠安卓模拟器 选择理由 看了一眼桌面,就这个比较有意思.现在很多人喜欢玩手游,经常喜欢开个小号搞事情.这时候身边又没有多余的手机,怎么办?安卓模拟器下一个.手机屏幕太小玩起来没意思怎么 ...
- 设计模式NO.3
设计模式NO.3 本次博客内容为第三次设计模式的练习.根据老师的要求完成下列题目: 题目1 某商品管理系统的商品名称存储在一个字符串数组中,现需要自定义一个双向迭代器(MyIterator)实现对该商 ...
- 学生ID查询
var http = require("http"); var server = http.createServer(function(req,res){ //得到url var ...
- prototype 原型链
// 方法1 var aa=function(){ function bb(){ this.name="1111"; console.log(this.name) }; bb.pr ...
- 命令行窗口中用telnet测试HTTP协议
1. 命令行窗口中用telnet测试HTTP协议 HTTP消息是由普通ASCII文本组成.消息包括消息头和数据体部分.消息头以行为单位,每行以CRLF(回车和换行)结束,消息头结束后,额外增加一个CR ...
- JAVA_SE基础——30.构造代码块
黑马程序员入学blog...构造代码块作用:给所有的对象进行统一的初始化. 问题:要求每个小孩出生都会哭,这份代码有两个构造函数,如果需要每个小孩出生都要哭的话,那么就需要在不同的构造函数中都调用cr ...