前端学习(三十四)对象&模块化(笔记)
人,工人
//类的定义
function Person(name,age){ //构造函数
//工厂模式
//1.原料
//var obj = new Object();
//2.加工
this.name = name;
this.age = age;
//3.出厂
//return obj;
}
//方法
Person.prototype.showName = function(){
return this.name;
};
//实例化
var p1 = new Person('zhangsan',28);
new:
1. 创建一个新的空白对象
2. 把这个对象赋值给 this
3. 自动返回this
//继承 工人 -> 人
1)继承属性
function Worker(name,age,job){
//继承父类属性
Person.apply(this,arguments);
//增加自己的属性
this.job = job;
}
2)继承方法
Worker.prototype = new Person();
Worker.prototype.constructor = Worker;
* 万物皆对象
* 能new的东西都是函数
* 构造函数约定首字母大写
* 实例化一个类的时候(new Person()),构造函数自动执行
* 类的原型 prototype 可以用来扩展系统方法
* 解决this:
1) 在this正确的地方,存一下
2) fn.call(this的指向,参数1...);
3) fn.apply(this的指向,[参数1....]);
4) bind
var a = fn.bind(this的指向,参数1);
a(参数2);
//this 正确
oBtn.onclick = function(){
//this 指向按钮,希望指向外面
}.bind(this);
* 类型检测
1) typeof : 基本类型
数字,字符串,布尔,undefined
2)instanceof : 用于检测 当前对象是不是某个类的实例, 包含父级以及一直向上
alert(p1 instanceof Person); √
alert(p1 instanceof Object); √
3)constructor:用户判断当前对象的是不是由某个类构造出来的
p1.constructor == Person
==========================
一、ES6前面向对象周边的知识
1、给一个类的原型上加方法时,要一个一个加,不能用一个JSON整体覆盖,否则,会把原来已经有的东西覆盖掉(prototype.constructor 被覆盖)
2、原型链
使用某个方法或属性时,先看自己有没有,如果自己有就用自己的,否则找父级...一直找到为止 —— Object
* 如果一个对象属于子类,那么这个对象必然属于这个子类的父类。
* 作用链:
var c = 100;
function aaa(){
var c = 5;
function bbb(){
//var c = 12;
alert(c);
}
bbb();
}
aaa();
show(1)(2)(3); —— 6 //返回函数
aa(1).bb(2).cc(3); —— 6 //返回JSON
3、所有东西都是对象?
基本类型不是对象。
除了基本类型外,其它的东西都是对象。
包装类型:
数字 Number
字符串 String
布尔 Boolean
undefined Undefined ×
* 包装类型,在JS中,没用。
4、单体模式/单例模式 设计模式
以前: 工厂模式
* 只有一个实例,不能扩展 —— 利用 JSON
let Person = {
name:'张三',
age:18,
showName(){
return this.name + '^_^';
}
};
5、命名空间
利用JSON,把一些独立的模块、频道、子系统 ,中使用的变量的包起来。
达到: 避免变量名冲突
例:
let top = {
a:12
}
let body = {
a:5
}
let footer = {
a:20
}
top.a
body.a
footer.a
变量冲突的解决:
1、封闭空间
2、面向对象 : 把相同的变量放到不同的对象里
3、命名空间(名称空间)
4、模块化
6、this 的问题
this: 发生事件的对象(元素),当前方法属于谁,this就是谁
对this优先级进行排序:只供参考
1) new > 定时器
2) 定时器 > 事件
3) 事件 > 方法
4) 其它 (window)
优先级: new > 定时器 > 事件 > 方法
7、js 中的 BUG (自相矛盾的地方)
1、Object 和 Function 互为爹,自称爹
* 一切都是对象
* 能new 都是函数
2、只认爹,不认爷
3、花祖宗的钱,不认祖宗
==========================
二、ES6面向对象
类、构造函数 —— 面向对象(java)
类:
定义——
//类
class Person{
//构造函数
constructor(name,age){
this.name = name;
this.age = age;
}
//方法
showName(){
return this.name;
}
showAge(){
return this.age;
}
}
使用——
let p1=new Person('zhang3',28);
继承:
class Worker extends Person{
constructor(name,age,job){
super(name,age); //相当于调用 父级 的构造函数
this.job = job;
}
showJob(){
return this.job;
}
}
*super —— 超类
==========================
用面向对象的方式写程序 , 没有统一的写法。
例1:点div变红
例2:选项卡
==========================
模块化:
一、什么,为什么
模块化:把一个大的系统,一个较复杂的功能,切分为若干个小部分。
有利于 系统的扩展、人员之间分工合作、可以提高效率...
二、JS中模块化:
09年,美国,一哥们,写了一个程序 —— NodeJS
标志着JS中模块化开发的开始。
三、JS中模块化遵循的标准:
CommonJs: NodeJS —— 同步
const express = require('express');
let server = express();
AMD: —— 异步
Asynchronous Module Definition 异步模块定义
库:requirejs
CMD:
库:seajs
官网: seajs.org
四、requirejs
安装:
1) 官网下载
http://requirejs.org/
2) npm i requirejs
前端学习(三十四)对象&模块化(笔记)的更多相关文章
- 前端学习(三十五)模块化es6(笔记)
RequireJs:一.安装.下载 官网: requirejs.org Npm: npm i requirejs二.使用 以前的开发方式的问题: 1).js 是阻塞加 ...
- 前端学习(十四):CSS布局
进击のpython ***** 前端学习--CSS布局 每个模块的相关央视就算是进本上都完成了,但是,这些模块想放在不同的位置 横着放,竖着放,斜着放... ... 想怎么放怎么放 那就用到了今天要说 ...
- 前端学习(三十六)promise(笔记)
一个页面: 头部.用户信息.新闻列表 jquery ajax: 1.$.ajax({ url:'', dataType:'json', }).then(res=>{ //r ...
- 前端学习(三十八)vue(笔记)
Angular+Vue+React Vue性能最好,Vue最轻=======================================================Angular ...
- 前端学习(三十)es6的一些问题(笔记)
赋值表达式 document.onclick = document.onmouseover = fn; var a = b = c = d = 5; 不推荐 逗号表 ...
- 前端学习(三十九)移动端app(笔记)
移动端App 开发App的三种方式 Native App 原生 底层语言 java Android oc ...
- 前端学习(三十七)angular(笔记)
MVC 后台 M Module 数据层 V View 视图层 C Contro ...
- 前端学习(三)css选择器(笔记)
字体样式: color:red: font-size:12px: font-weight:bold/normal; font-style:italic/normal; f ...
- Salesforce LWC学习(三十四) 如何更改标准组件的相关属性信息
本篇参考: https://www.cnblogs.com/zero-zyq/p/14548676.html https://www.lightningdesignsystem.com/platfor ...
随机推荐
- ubuntu + JetSonNano+OpenCV3.4.8
首先强调一点,如果要配置darknet环境,不建议安装该版本!!! 安装opencv前,建议先检测自己的系统是否已经装过其他版本, 检查方式: (1)查看是否安装opencv库: pkg-config ...
- dede标签大全
想必很多人对后台不熟悉,并且觉得很难.其实不难,只是你们没有找到合适的方法学习而已!只有找到一个合适的学习方法,不管做什么事情,我想都很容易.学习讲究的是效率,而效率又是由思路决定的.就拿网页制作来说 ...
- Centos7防火墙和SELinux的开启和关闭
在虚拟机里面开启多个服务,对应多个端口,在防火墙开启的情况下,就要对外开放端口,这样客户端才能正常访问,但比较繁琐,关闭更直接点. 防火墙 临时关闭防火墙 systemctl stop firewal ...
- 无题II
无题II Time Limit: 2000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- (转)使用windows server2008 创建 Hyper-V虚拟机
转:https://jingyan.baidu.com/article/7c6fb42833ad4980652c904f.html Hyper-v是微软提供的虚拟机,利用server 2008搭建hy ...
- 搭建maven本地仓库
1. 需先配置java环境. 2. 下载nexus. https://www.sonatype.com/download-nexus-repo-oss?submissionGuid=a015a3db- ...
- Jenkins使用五:创建部署任务
创建部署任务 选择运行节点 选择使用shell # 如果是持续进程,这里最好加一个kill进程的命令 判断如果/root/production目录存在,就删除if [ -d /root/product ...
- Codeforces 1197 E (dp+sort+二分) (Rust)
原题链接 2300分 大意 俄罗斯套娃,每个有内容半径in和外围半径out in_i<out_i 如果 in_i >= out_j ,那么j可以放在i内 定义残留空间 = 一列嵌套的套娃 ...
- thphp(tp5)项目网站从Apache换成nginx报500
thphp(tp5)项目网站从Apache换成nginx报500 百度了一下,查看资料是Nginx配置fastcgi.conf的问题,打开文件编辑既可,如下图:
- Learning OSG programing---Multi Camera in one window 在单窗口中创建多相机
在学习OSG提供的例子osgCamera中,由于例子很长,涉及很多细节,考虑将其分解为几个小例子.本文介绍实现在一个窗口中添加多个相机的功能. 此函数接受一个Viewer引用类型参数,设置图形上下文的 ...