js的面向对象开发能力较弱,基本是以prototype为核心的面向对象,虽然现在出了个class这玩意,但本文还是先不做探讨. 面向对象基础——构造函数方法 var Fly = function (speed) { this.power = "i can fly"; this.speed = speed+"km/h"; this.init = function(){ console.log(" i will fly and my speed is &quo…
一.js中的两种对象,普通对象和函数对象 var obj1 = {}; var obj2 =new Object(); var obj3 = new obj1(); function fun1(){}; var fun2 = function(){}; var fun3 = new Function('str','console.log(str)'); 第一种是普通对象,第二种是函数对象.上面两种对象三种情况,我们首先来分析一下对象,在js中如何实现面向对象思想,所谓的面向对象,对象基于模板来创…
js面向对象怎么理解 <一>. 认识对象.首先要认识对象:在编程中,对象(object)是具体的某一个实例,唯一的某一个个体.如:电脑就是一个统称,而你面前的这一台电脑就是对象.而电脑的统称在编程中叫做类,概念就是:具有一类相同特征事物的抽象概念.在js中只有对象的概念.没有类的概念,在ECMA6中必须加回来.对象的语法:(创建对象) var obj1 = new Object(); var obj2 = Object(); var obj3 = {};<二>. 在js中面向对…
一.扯淡部分 很久很久以前,也就是刚开始接触前端的那会儿,脑袋里压根没有什么架构.重构.性能这些概念,天真地以为前端===好看的页面,甚至把js都划分到除了用来写一些美美的特效别无它用的阴暗角落里,就更别说会知道js还有面向对象,设计模式,MVC,MVVM,模块化,构建工具等等这些高大上的概念了.现在想想还真是Too young too naive.前两天某大神在群里分享他招聘前端的心得的时候就说,就是那些以为能写两个页面就可以自称前端的人拉低了行业水平.这样看来前两年我还真的扯了不少后腿呢………
EcmaScript 2015 (又称ES6)通过一些新的关键字,使类成为了JS中一个新的一等公民.但是目前为止,这些关于类的新关键字仅仅是建立在旧的原型系统上的语法糖,所以它们并没有带来任何的新特性.不过,它使代码的可读性变得更高,并且为今后版本里更多面向对象的新特性打下了基础. 在介绍 class 继承以前,先来回忆一下没有 class 之前类是怎么被创建和继承的: 1.定义 function father 构造函数,再通过 prototype 定义 father 类原型方法. 2.定义 f…
class 相对 function 是后出来的,既然 class 出来了,显然是为了解决 function 在处理面向对象设计中的缺陷而来.下面通过对比,来看看 class 作为 ES6 中的重大升级之一的优势在哪里:为了更好的对比,请参见我的另外一篇博文: js面向对象设计之 function 类. 1.class 写法更加简洁.含义更加明确.代码结构更加清晰.2.class 尽管也是函数,却无法直接调用(不存在防御性代码了).3.class 不存在变量提升.4.class 为污染 windo…
Js面向对象编程 1. 什么是面向对象编程? 我也不说不清楚什么是面向对象,反正就那么回事吧. 编程有时候是一件很快乐的事,写一些小游戏,用编程的方式玩游戏等等 2. Js如何定义一个对象 一般变量的定义方法 var name = '小明'; var email = 'xiaoming@chinaedu.net'; var website = 'http://chinaedu.net'; 写成对象的方式: var xiaoming = { name : '小明', email :…