这节课好多内容没搞懂!!!需要再看看
预习: 没有复习!!!
请尝试理解面向对象,并背诵 MDN 里的以下内容
Class 类
定义对象的特征。它是对象的属性和方法的模板定义.
Object 对象
类的一个实例。
Property 属性
对象的特征,比如颜色。
Method 方法
对象的能力,比如行走。
Constructor 构造函数
对象初始化的瞬间, 被调用的方法. 通常它的名字与包含它的类一致.
Inheritance 继承
一个类可以继承另一个类的特征。
Encapsulation 封装
一种把数据和相关的方法绑定在一起使用的方法.
Abstraction 抽象
结合复杂的继承,方法,属性的对象能够模拟现实的模型。
Polymorphism 多态
多意为‘许多’,态意为‘形态’。不同类可以定义相同的方法或属性。
问题:1||2的值是多少?
data:image/s3,"s3://crabby-images/db3bd/db3bd992ea825b593e3651e36a8515d410233653" alt=""
js的或操作符(a||b)和且操作符(c&&d)的值基本上不可能是true/false
五个falsy值:'',0,NaN,null,undefined
data:image/s3,"s3://crabby-images/9ff90/9ff900f5263a3aef44b3aeff9805aa4ddc4e35e4" alt=""
console.log(3)的值是undefined
- 用&&操作符的时候,找假值,返回找到的第一个假值
如果没有找到假值,就返回最后一个真值
1&&2&&3 //结果是3 -
用||操作符的时候,找真值,返回找到的第一个真值
image.png
理解 var a = a || {}什么意思
var a = a || {}
//等价于
if(a){
a=a
}else{
a={}
}
用来防止覆盖之前a的值(危险代码)
data:image/s3,"s3://crabby-images/29e7a/29e7a17d88b0a73c685792f195337db25127e14e" alt=""
理解命名空间
// 全局命名空间
var MYAPP = MYAPP || {};
// 子命名空间
MYAPP.event = {};
讲义
箭头函数内外的this是同一个???
data:image/s3,"s3://crabby-images/bfa57/bfa575840edd809a9d01c52eb0b61ede49fe26c2" alt=""
data:image/s3,"s3://crabby-images/461c4/461c43e11cd6a8711f496ec573df8c5a0940f3ac" alt=""
-
封装view
封装View.png
data:image/s3,"s3://crabby-images/e0a5d/e0a5d6f1be09bf29e5465bb4b58f7da9e159130b" alt=""
data:image/s3,"s3://crabby-images/32e93/32e9350fe3965f658cb2558c879976e9b9dd2ac9" alt=""
-
封装model
model_原.png
封装Model.png
image.png
data:image/s3,"s3://crabby-images/f56b9/f56b9e43081d886cccdf9dbe9bda76a16b568376" alt=""
data:image/s3,"s3://crabby-images/5813b/5813bf93c77024cb6b79721d735993d7d2cea3f3" alt=""
data:image/s3,"s3://crabby-images/54e8d/54e8de06dcd8d65630d0117fbafd891612c3899d" alt=""
save方法也需要改,怎么改???
用到了闭包
你办事,我放心
model办事,我放心
data:image/s3,"s3://crabby-images/38539/3853999fc39ef9ea94e2919336222057435e48bd" alt=""
- 封装Controller(没看懂)给对象一个类
data:image/s3,"s3://crabby-images/137d9/137d90319a020a7af044a83c224ab855a92828c2" alt=""
data:image/s3,"s3://crabby-images/b6283/b6283b4fe566c655eac5645a05c6655a94aae792" alt=""
data:image/s3,"s3://crabby-images/81e68/81e680c01ecb5993a1d6b064bb9014ce947cc1ca" alt=""
data:image/s3,"s3://crabby-images/dd79e/dd79eedd0b65408957b61a06bbf836ec59a96dd3" alt=""
data:image/s3,"s3://crabby-images/d0913/d09137ab8e4133ceda9ff0c9e6f7b5e9f144441f" alt=""
data:image/s3,"s3://crabby-images/325c4/325c4734b46d74ef3718cc76e42ddf9bb1ae9bb3" alt=""
封装 Model View Controller
完整代码:https://github.com/FrankFang/resume-15-8
- controller === object
- controller.init(view, model)
controller.init.call(controller, view, model)
那么 controller.init 里面的 this 当然 TM 是 controller
也就是这个1里面的object
controller.init 里面的 this 就是 object
object.init 里面的 this 就是 object - initB.call(this)
initB 里面的 this === call 后面的this
call 后面 this === 第二条里的 this
第二条里面的 this === object
=> initB 里面的 this 就是 object
复习 this
问题⬇️
data:image/s3,"s3://crabby-images/276a4/276a46e7393ba6f0bf4c71030a7daae4c8777a37" alt=""
data:image/s3,"s3://crabby-images/7ce30/7ce3088e3e215d0b6845f3860511062f2a8bd65b" alt=""
data:image/s3,"s3://crabby-images/01a54/01a54a29492be2f7873f65426dc89888f798affc" alt=""
google mdn onclick
data:image/s3,"s3://crabby-images/dc3c0/dc3c0c2240ad509be11369aeef76dfba823c8662" alt=""
data:image/s3,"s3://crabby-images/73e67/73e67ee2e1ad403d626b46f8dc1114fb5a1ea03d" alt=""
button.onclick = function f1(){
console.log(this) // 触发事件的元素。 button
}
button.onclick.call({name: 'frank'})
button.addEventListener('click', function(){
console.log(this) // 该元素的引用 button
}
2 结果
$('ul').on('click', 'li' /*selector*/, function(){
console.log(this) //this 则代表了与 selector 相匹配的元素。
// li 元素
})
3 结果
去看 on 的源码呀 -> 做不到
jQuery 的开发者知道 onclick 的源码,f1.call(???)
jQuery 的开发者写了文档
看文档呀
this是call()的第一个参数,看不到call()就不能确定this是什么,智能去看对应的文档说明,看看this指的是什么!!!
function X(){
return object = {
name: 'object',
options: null,
f1(x){
this.options = x
this.f2() //调用的是A还是B?
},
f2(){
this.options.f2.call(this) //A?this 是啥 ?
}
}
}
var options = {
name: 'options',
f1(){},
f2(){
console.log(this) //B?this 是啥 ?
}
}
var x = X()
x.f1(options)
答案:B options
data:image/s3,"s3://crabby-images/7c378/7c3783675f89fb09351a4a81a3cf3f0824ea2e6d" alt=""
答案:D object
data:image/s3,"s3://crabby-images/c2807/c280776a9d3c93dd58e5994eb8947fa673b8a3c2" alt=""
答案:object
new 的作用
https://zhuanlan.zhihu.com/p/23987456
data:image/s3,"s3://crabby-images/f6abb/f6abbb59de825881beb70dd47d83ce65b3ed70a1" alt=""
data:image/s3,"s3://crabby-images/e47c0/e47c0f31a2be230ac6c5694ef2c2ffb02045f630" alt=""
data:image/s3,"s3://crabby-images/58367/5836704a42301a31428616b2c90a9311bc0ed452" alt=""
var object = new Object()
自有属性 空
object.proto === Object.prototype
var array = new Array('a','b','c')
自有属性 0:'a' 1:'b' 2:'c',length:3
array.proto === Array.prototype
Array.prototype.proto === Object.prototype
var fn = new Function('x', 'y', 'return x+y')
自有属性 length:2, 不可见的函数体: 'return x+y'
fn.proto === Function.prototype
Array is a function
Array = function(){...}
Array.proto === Function.prototype
课后习题:
网友评论