js下 Day13、面向对象
一.对象
什么是对象: 一组无序的属性集合
创建对象两种方式:
对象字面量: var obj = {}
实例化: var obj = new Object()
对象取值:
**[] ( ** 中括号): 变量、数字等不规范的属性名
.(点) : 符合命名规范的属性名
删除对象的属性: delete 对象.属性名
遍历对象**:for(var key in obj){}**
#二.作用域
全局作用域: 全局变量拥有全局作用域,可以在任何地方使用
局部作用域: 局部变量拥有局部作用域,只能在定义的函数内使用
变量提升: 使用var关键字声明的变量会将(var 变量名)提升到当前作用域最顶端,赋值留在原地
函数提升: 函数声明会提升到当前作用域的最顶端
变量提升 > 函数提升
#三.this指向
this在JS中指的是执行上下文环境对象
全局中的this | Window |
---|---|
函数中的this | 直接调用 => window |
事件处理函数中 => 事件源 | |
对象调用 => 对象 | |
构造函数中的this => 实例化对象 |
总结: 函数中的this,谁调用指向谁
#四.面向对象
#1. 什么是面向对象
面向对象是一种程序设计模式(编程思想),将对象作为基本单元,将程序和数据封装其中
#2. 为什么使用面向对象
可重用、可维护性好、可扩展、灵活性好
#3. 工厂模式
为什么使用工厂模式: 解决了创建多个相似对象(结构相同)的问题
#4. 构造函数模式
为什么使用构造函数模式: 解决了对象识别问题,区分普通函数和构造函数
构造函数必须通过new运算符来调用
构造函数首字母大写(不是必须,一种规范,用于区分构造函数和普通函数)
#5. 原型模式
在原型对象中定义共有的属性和方法
为什么使用原型模式: 解决了多个对象具有相同的属性或方法被重复创建的问题
prototype => 构造 找 原型
constructor => 原型 找 构造
proto => 实例找原型
构造函数写属性,原型对象写方法
#6. 框架搭建
面向对象三部曲:
1. 构造函数
2. 原型对象
3. 实例化
#五.案例--选项卡三级联动
效果图:
功能思路分析:
1. 数据分析
\1. 对象结构的数据,使用for in 遍历
\2. 属性名是数字,使用[]取值
\3. 省市区的数据没有嵌套,是同级关系,使用code属性关联
2. 省份渲染
\1. 通过 cityData.city拿到省份数据,对象结构用for in遍历
\2. 根据属性名渲染字母分类
\3. 每个分类下是数组,使用map().join(“”) 嵌套渲染省份
\4. 渲染时将省份编码code,通过自定义属性绑定在标签上
3. 城市渲染
1.通过事件委托给省份盒子绑定点击事件
2.点击省份时,拿到标签上的自定义属性code(getAttribute())
3.对象数据用for in渲染
4.渲染时将城市编码code,通过自定义属性绑定在标签上
5.调用选项卡切换方法,传递城市盒子的下标,显示城市盒子
4. 区域渲染
1.通过事件委托给城市盒子绑定点击事件
2.点击城市时,拿到标签上的自定义属性code(getAttribute())
3.对象数据用for in渲染
4.渲染时将区域编码code,通过自定义属性绑定在标签上
5.调用选项卡切换方法,传递区县盒子的下标,显示区县盒子
5. 选项卡切换
\1. 给导航大盒子绑定点击事件,使用委托委托实现选项卡效果
\2. 封装一个公用的且、切换方法
3. 让上一个导航和内容盒子去掉类名(classList.remove),修改初始下标为当前下标(传参得到当前下标),让当前下标的导航和内容盒子加上类名( classList.add() )
#六.今日小结
**1. ** 对象
对象取值:
**[] ( ** 中括号): 变量、数字等不规范的属性名
**. ** (点) : 符合命名规范的属性名
遍历对象**:for(var key in obj){}**
**2.this ** 指向
全局中的this指向window
函数中的this:
直接调用,this 指向window。
在事件处理函数中,this 指向绑定事件的元素。
在对象方法中,this指向调用该方法的对象。
构造函数中, this指向实例化的对象
总结:谁调用指向谁
**2. ** 面向对象
面向对象三部曲: 构造函数 原型对象 实例化
prototype => 构造 找 原型
constructor => 原型 找 构造
proto => 实例找原型
!!!牢记框架
#七.作业 -- 软键盘拖拽
效果图:
功能思路分析:
必做功能点:
\1. 点击文本框时显示键盘
\2. 点击X 或页面其他区域隐藏键盘
\3. 键盘拖拽
\4. 点击键盘中按键将对应内容输入到文本框
扩展功能点:
\1. shift按键的大小写转换
\2. 清空按钮清空文本框内容
js下 Day13、面向对象的更多相关文章
- js下的面向对象
本文记录了一种Javascript的面向对象方法及原理理解,示例代码如下: //构造函数 var MClass = function(value1, value2) { this.member = & ...
- Day046--JavaScript-- DOM操作, js中的面向对象, 定时
一. DOM的操作(创建,追加,删除) parentNode 获取父级标签 nextElementSibling 获取下一个兄弟节点 children 获取所有的子标签 <!DOCTYPEhtm ...
- python 全栈开发,Day52(关于DOM操作的相关案例,JS中的面向对象,定时器,BOM,client、offset、scroll系列)
昨日作业讲解: 京东购物车 京东购物车效果: 实现原理: 用2个盒子,就可以完整效果. 先让上面的小盒子向下移动1px,此时就出现了压盖效果.小盒子设置z-index压盖大盒子,将小盒子的下边框去掉, ...
- 前端JavaScript(3)-关于DOM操作的相关案例,JS中的面向对象、定时器、BOM、位置信息
小例子: 京东购物车 京东购物车效果: 实现原理: 用2个盒子,就可以完整效果. 先让上面的小盒子向下移动1px,此时就出现了压盖效果.小盒子设置z-index压盖大盒子,将小盒子的下边框去掉,就可以 ...
- 轻松理解JS中的面向对象,顺便搞懂prototype和__proto__
这篇文章主要讲一下JS中面向对象以及 __proto__,ptototype和construcator,这几个概念都是相关的,所以一起讲了. 在讲这个之前我们先来说说类,了解面向对象的朋友应该都知道, ...
- 轻松理解JS中的面向对象,顺便搞懂prototype和__proto__的原理介绍
这篇文章主要讲一下JS中面向对象以及 __proto__,ptototype和construcator,这几个概念都是相关的,所以一起讲了. 在讲这个之前我们先来说说类,了解面向对象的朋友应该都知道, ...
- 原生JS下拉加载插件分享。
无聊写了一个JS下拉加载插件,有需要的可以下载. // 使用 // new ManDownLoad("#ul","json/load.json",functio ...
- js下拉框
Js下拉框 http://sc.chinaz.com/tag_jiaoben/XiaLaKuang.html
- CSS+JS下拉菜单和纯CSS下拉菜单
下拉菜单 (思路:先把二级定位到屏幕外,鼠标悬停重新定位回来:另一个就是ul浮动,li也浮动) 下拉菜单的一般思路就是把子导航嵌套在无序列表中,把列表定位到屏幕之外,当鼠标悬停在其父列表项上时,重新定 ...
随机推荐
- vue项目中h5移动端中通过flex布局实现首尾固定,中间滚动(借鉴)
html中 <div class="flexLayoutr"> <div class="div_head"></div> & ...
- 面经分享!蚂蚁金服三面被拒,重拾起鼓四面猿辅导成功拿下offer!
前言 一直有小伙伴要我分享面经,说自己想面互联网公司,无奈经验太少想多看看其他人是怎么面的.我这两天刚好和一个刚拿到猿辅导offer的朋友吃了个饭,他向我说了说自己的面试经历.粉丝朋友是末流211毕业 ...
- 了解 MySQL的数据行、行溢出机制吗?
目录 一.行 有哪些格式? 二.紧凑的行格式长啥样? 三.MySQL单行能存多大体量的数据? 四.Compact格式是如何做到紧凑的? 五.什么是行溢出? 六.行 如何溢出? 七.思考一个问题 关注送 ...
- 使用Camtasia来消除视频中的声音
大多数情况下,我们在录制电脑屏幕的时候都会把音频输出也一起录制下来,但也会有时候要后期进行重新配音,需要把事先一同录制的音频消除掉,今天小编来给大家说一说如何消除这种的视频声音. 首先打开Camtas ...
- Mac中的格式转换如何用读写工具Tuxera NTFS完成
Tuxera NTFS for Mac是一款专门为Mac用户提供的NTFS驱动软件,它不仅可以进行磁盘文件的访问.编辑.传输和存储,还可以对硬盘进行维修检查以及修复. 今天小编就给大家简单介绍一下Tu ...
- 惠州发布5G任务计划表,将出台智慧灯杆建设计划与技术规范
广东省惠州市于近日发布<惠州市贯彻落实广东省加快5G产业发展行动计划(2019-2022年)工作任务计划表>(以下简称:<5G任务计划表>). <5G任务计划表>明 ...
- 解决YUM下Loaded plugins: fastestmirror Determining fastest mirrors 的错误问题
最近想再购买一台虚拟服务器做项目测试,之前在西部数码购买的已经过期了,在同事的推荐下去搬瓦工购买了一台服务器,听他介绍在这里购买服务器很便宜($19.99/年)而且还是国外的,看着相比之前的确实挺便宜 ...
- 创建topic
sh kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic ...
- moviepy音视频剪辑VideoClip类fl_image方法image_func报错ValueError: assignment destination is read-only解决办法
☞ ░ 前往老猿Python博文目录 ░ moviepy音视频剪辑模块的视频剪辑基类VideoClip的fl_image方法用于进行对剪辑帧数据进行变换. 调用语法:fl_image(self, im ...
- 第8.29节 使用MethodType将Python __setattr__定义的实例方法与实例绑定
一. 引言 在<第7.14节Python类中的实例方法解析>介绍了使用"实例对象名.方法名 = MethodType(函数, 对象)"将动态定义的方法与实例进行绑定 在 ...