一、构造函数的使用

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>面向对象编程</title>
</head>
<body>
<script>
/*构造函数(构造函数命名一般此采用大驼峰式命名即驼峰式命名首字母大写)*/
// 构造函数中的this指向的是即将生成的对象
// ES5的语法
function Es5Person(name) {
this.name = name;
this.sleep = function () {
console.log('喜欢睡觉!');
};
}
// ES6语法
class Es6Person {
constructor(name) {
this.name = name;
}
//定义方法省略关键字,且方法直接绑定到原型对象
sleep() {
console.log('喜欢睡觉!');
}
}
var personOne = new Es5Person('小明');
var personTwo = new Es6Person('小张'); console.log(personOne);
console.log(personTwo);
</script>
</body>
</html>

二、构造函数和对象的关系

对象是由构造函数new 出来的,即对象是构造函数的实例。

三、使用JSON创建对象

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>面向对象编程</title>
</head>
<body>
<script>
// json创建对象的方式(适合单个对象)
const liuneng = {
name: '刘能',
sleep: function () {
console.log('喜欢睡觉!');
}
};
console.log(liuneng);
</script>
</body>
</html>

四、面向对象和面向过程的区别

1)面向过程:面向过程专注于如何去解决一个问题的过程步骤。编程特点是由一个个函数去实现每一步的过程步骤,没有类和对象的概念。
2)面向对象:专注于由哪一个对象来解决这个问题,编程特点是出现了一个类,从类中拿到对象,由这个对象去解决具体问题。
 对于调用者来说,面向过程需要调用者自己去实现各种函数。而面向对象,只需要告诉调用者,对象中具体方法的功能,而不需要调用者了解方法中的实现细节。

七、类和对象

 类 :对一群具有相同特征的对象的集合的描述;

对象:真实存在的对象个体;

对象和类的理解:面向对象,而不是面向类。

  类只是我们用来组织对象和构造程序的一种形式,它本质上源自于人们对于现实世界中的一种概念映射,即:凡是具有共同点的部分便可以抽象成一类,抽象层次越高,类在继承体系中的层级越高(或者说越低,看你从哪个方向来看了,总之就是越来越基础,直到成为一切衍生类型的始祖)。

  在 Javascript 里,一切对象归根结底都是源自于 Object,如果你扩展(重载)了 Object 的原型(Javascript 基于原型继承),那么其他的一切对象都可以获得这些扩展(重载)。所以在 Javascript 的世界里,类不是必须的,没有类一样可以面向对象。

  Javascript中function作为构造函数时,就是一个类(类本质也是个函数),搭配上new操作符,可以返回一个对象。

  在JavaScript中采用构造函数来模拟类,只是为了能在应用的业务领域里重现基于类语言的那种类型化(更容易和我们看待事物的方式相匹配),但是由于一些语言设计上的不足甚至是错误,使得 Javascript 很难完整的实现经典类型系统。继承靠原型链,多态靠弱类型,封装靠闭包。

八、JSON字符串和对象直接的转换

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>面向对象编程</title>
</head>
<body>
<script>
// 对象转字符串(方法不会被序列化,只保留属性)
var obj1 = {name: '张三', hello: function () {}};
console.log(JSON.stringify(obj1)); // 字符串转对象(字符串内容要用双引号包裹,单引号包裹无法识别)
var obj2 = '{"name": "张三"}';
console.log(JSON.parse(obj2));
</script>
</body>
</html>

附录:类实现模态框

目录结构:

1.html页面

<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>模态框</title>
<link rel="stylesheet" type="text/css" href="styles/common.css">
<link rel="stylesheet" type="text/css" href="styles/index.css">
</head>
<body>
<div class="test">
<input id="popupBtn" class="popupBtn" type="button" value="弹出框"/>
</div>
</body>
<script type="text/javascript" src="scripts/popup.js"></script>
<script type="text/javascript" src="scripts/common.js"></script>
<script type="text/javascript" src="scripts/index.js"></script>
</html>

index.html

2.js文件

公用js

/*函数名称:getTagByClassName                 */
/*函数功能:通过calss属性值获取对应的标签元素*/
/*创 建 人:石勇龙 */
/*创建时间:2018、01、10 */
/*----------------参数说明:---------------- */
/*形参className:标签的class属性值 */
function getTagByClassName(className) {
if (document.getElementsByClassName) {
return document.getElementsByClassName(className);
}
else{
var allTags=document.document.getElementsByTagName("*");
var result=[];
var allTagsArr=Array.from(allTags);
allTagsArr.forEach(function (v,i) {
v.className==className||result.push(v);
});
return result;
}
} /*函数名称:$ */
/*函数功能:通过id属性值获取对应的标签元素*/
/*创 建 人:石勇龙 */
/*创建时间:2018、01、10 */
/*---------------参数说明:-------------- */
/*形参value:标签的id属性值或class属性值 */
function $(value) {
if (value.charAt()==="#") {
return document.getElementById(value.substring());
}
else if (value.charAt()===".") {
return getTagByClassName(value.substring());
}
} /*函数名称:bufferMove */
/*函数功能:元素的变速运动 */
/*创 建 人:石勇龙 */
/*---------------参数说明:-------------- */
/*obj:运动对象 */
/*target:运动属性及目标(类型:对象) */
/*ratio:运动系数 */
/*fun:回调函数实现链式运动 */
function bufferMove(obj,target,ratio=,fun) {
clearInterval(obj.timer);
obj.timer=setInterval(function () {
var flag=true;
for(var attr in target){
//获取当前值
var cur=;
if (attr==="opacity") {
cur=parseInt(getStyle(obj,"opacity")*)
}
else{
cur=parseInt(getStyle(obj,attr))
}
//计算速度
var speed=(target[attr]-cur)/ratio;
//判断运动方向
var speed=speed>?Math.ceil(speed):Math.floor(speed);
//获取下次运动位置
var nextValue=cur+speed;
//设置当前运动位置
if (attr==="opacity") {
obj.style.opacity=cur/;
obj.style.filter="alpha(opacity="+nextValue+")";
}
else{
obj.style[attr]=nextValue+"px";
}
//判断运动是否结束
if (target[attr]!=nextValue) {
flag=false;
}
}
if (flag) {
clearInterval(obj.timer)
if(fun){
fun();
}
}
},)
} /*非行内样式获取*/
function getStyle(obj,attrname) {
if (obj.currentStyle) {
return obj.currentStyle[attrname];
}
else{
return getComputedStyle(obj,false)[attrname];
}
}

common.js

模态框js

const Popup={
oContaiter:null,
create(){
this.oContaiter = document.createElement("div");
this.oContaiter.className = "contaiter";
document.body.appendChild(this.oContaiter);
this.oContaiter.onclick = function (ev) {
e = ev || window.event();
var oTarget = e.target || e.srcElement;
if(oTarget.className == "modal-close"||oTarget.className == "cancleBtn"){
this.style.display = "none";
}
};
},
modalDialog({modalTitle,modalContent}){
if (!this.oContaiter) {
this.create()
}
this.creaModalUI({modalTitle,modalContent});
this.oContaiter.style.display = "block";
bufferMove(this.oContaiter.getElementsByClassName('modal-dialog')[],{marginTop:});
},
creaModalUI({modalTitle,modalContent}){
this.oContaiter.innerHTML=
`
<div class="modal-dialog">
<div class="modal-header">
<div class="modal-title">
<h2>${modalTitle}</h2>
<a class="modal-close" href="#">&times;</a>
</div>
</div>
<div class="modal-content">
${modalContent}
</div>
<div class="modal-footer">
<input class="cancleBtn" type="button" value="取消">
<input class="commitBtn" type="submit" value="提交">
</div>
</div>
`;
this.oContaiter.getElementsByClassName('modal-dialog')[].style.marginTop=-this.oContaiter.getElementsByClassName('modal-dialog')[].offsetHeight+"px";
}
}

popup.js

页面js

var oPopupBtn = $("#popupBtn");
oPopupBtn.onclick = function () {
Popup.modalDialog({
modalTitle:'模态框标题',
modalContent:'模态框内容模态框内容模态框内容模态框内容模态框内容模态框内容模态框内容模态框内容模态框内容模态框内容'
}) }

index.js

3.css文件

公用css

@charset "utf-8";
/* CSS Document */
body,div,p,ul,ol,li,dl,dt,dd,table,tr,td,form,hr,fieldset,h1,h2,h3,h4,h5,h6,img,input{
margin:;
padding:;
}
html,body{
height: %;
}
body{
font-family: "微软雅黑",Arial;
background: #ebebeb;
}
a{
text-decoration:none;
}
ul,ol{
list-style:none;
}
img{
border: ;
}

common.css

页面css

/* contaiter 模态框背景层 */
.contaiter{
width: %;
height: %;
overflow: hidden;
position: fixed;
top: ;
left: ;
right: ;
bottom: ;
z-index: ;
background: rgba(,,,.);
}
/* modal-dialog 模态框弹出框 */
.modal-dialog{
margin: 40px auto;
width: %;
border-radius: 15px;
border: 1px dashed #f4f4f4;
background: #ffffff;
box-shadow: 10px #;
outline: none;
}
/* modal-close 关闭模态框 */
.modal-close{
position: absolute;
font-size: 36px;
color: #;
right: 20px;
top: 10px;
}
/* modal-header 模态框头部 */
.modal-header{
position: relative;
padding: 20px;
border-bottom: 1px dashed #f4f4f4;
}
.modal-title{
font-size: 16px;
}
/* modal-content 模态框内容区 */
.modal-content{
padding: 20px;
font-size: 16px;
}
/* modal-footer 模态框底部 */
.modal-footer{
border-top: 1px solid #f4f4f4;
padding: 20px;
text-align: right;
}
.modal-footer input{
margin: 10px;
display: inline-block;
padding: 10px 20px;
outline: none;
border: 1px solid #;
background: #ffffff;
border-radius: 10px;
box-shadow: 2px #;
}
.modal-footer .commitBtn{
background: #008B00;
color: #ffffff;
} /* popupBtn */
.popupBtn{
margin: 10px;
display: inline-block;
padding: 10px 20px;
outline: none;
border: 1px solid #;
background: #ffffff;
border-radius: 10px;
box-shadow: 2px #f4f4f4;
background: #ff0000;
}

index.css

从零开始学习前端JAVASCRIPT — 11、Ajax-前后端异步交互以及Promise-异步编程的改进的更多相关文章

  1. 从零开始学习前端JAVASCRIPT — 11、JavaScript运动模型及轮播图效果、放大镜效果、自适应瀑布流

    未完待续...... 一.运动原理 通过连续不断的改变物体的位置,而发生移动变化. 使用setInterval实现. 匀速运动:速度值一直保持不变. 多物体同时运动:将定时器绑设置为对象的一个属性. ...

  2. 从零开始学习前端JAVASCRIPT — 14、闭包与继承

    一.闭包 1 . 概念:闭包就是能够读取其他函数内部变量的函数.在JS中,只有函数内部的子函数才能读取局部变量,因此可以把闭包简单理解为”定义在一个函数内部的函数”. 2 . 闭包的特点 1)可以读取 ...

  3. ajax前后端数据交互简析

    前端-------->后端 方法:POST 将要传递给后台的数据在前端拼接成url字符串,通过request.send()传递给后台,后台php把得到的数据以索引数组的方式存储在$_POST中. ...

  4. 从零开始学习前端JAVASCRIPT — 1、JavaScript基础

    1:定义:javascript是一种弱类型.动态类型.解释型的脚本语言. 弱类型:类型检查不严格,偏向于容忍隐式类型转换. 强类型:类型检查严格,偏向于不容忍隐式类型转换. 动态类型:运行的时候执行类 ...

  5. 从零开始学习前端JAVASCRIPT — 10、JavaScript基础ES6(ECMAScript6.0)

    ECMAScript 6.0(简称ES6)是JavaScript语言的下一代标准,已经在2015年6月正式发布了.它的目标,是使得JavaScript语言可以用来编写复杂的大型应用程序,成为企业级开发 ...

  6. 从零开始学习前端JAVASCRIPT — 7、JavaScript基础EVENT

    1:事件驱动 1)事件:所谓事件就是js侦测到的用户的操作或是页面的一些行为(怎么发生的) 2)事件源对象:引发事件的元素.(发生在谁的身上) 3)事件处理程序:对事件处理的程序或是函数 (发生了什么 ...

  7. 从零开始学习前端开发 — 11、CSS3选择器

    一.基本选择器 1.* 通配符(通用选择器) 2.id选择器 3.class选择器(类选择器) 4.标签选择器(元素选择符) 5.群组选择器 (选择符1,选择符2{...}) 二.层次选择器(关系选择 ...

  8. 从零开始学习前端JAVASCRIPT — 4、JavaScript基础Math和Date对象的介绍

    Math对象的介绍 1:Math对象 Math 对象用于执行数学任务.并不像 Date 和 String 那样是对象的类,因此没有构造函数 Math().您无需创建它,通过把 Math 作为对象使用就 ...

  9. 从零开始学习前端JAVASCRIPT — 3、JavaScript基础string字符串介绍

    1:字符串 JS中的任何数据类型都可以当作对象来看.所以string既是基本数据类型,又是对象. 2:声明字符串 基本数据类型:var sStr = '字符串'; 对象的方法:var oStr = n ...

随机推荐

  1. Spring学习之路三——第一个Spring程序(体会IoC)

    体会IoC:Spring通过一种称作控制反转(IoC)的技术促进了松耦合.当应用了IoC,一个对象依赖的其它对象会通过被动的方式传递进来,而不是这个对象自己创建或者查找依赖对象.你可以认为IoC与JN ...

  2. ora-01190和ora-01110的解决方法

    SQLPLUS>ALTER DATABASE DATAFILE 2 ONLINE; ALTER DATABASE DATAFILE 2 ONLINE * ERROR 位于第 1 行: ORA-0 ...

  3. "Cache-control”常见的取值private、no-cache、max-age、must-revalidate及其用意

    http://www.cnblogs.com/kaima/archive/2009/10/13/1582337.html 网页的缓存是由HTTP消息头中的"Cache-control&quo ...

  4. Linux上常用软件安装和总结

    Linux总结: 以前只顾着撸码,Linux这些一般都是运维玩的,然后也没怎么折腾过,每次上线也都只是发布下,最多也就是启停服务器.最近闲来无事就玩了玩Linux,还挺好的. 这里做一个总结来结束Li ...

  5. 防盗链[referer]

    原文出处:http://www.cnblogs.com/devilfree/archive/2012/09/11/2680914.html 总结一下今天学习防盗链Filter的一些知识点: 防盗链要实 ...

  6. java编程中常用英语单词

    JAVA 省略语与名词解释 -------------------------------- J2EETM----JavaTM 2PlatformEnterpriseEdition : J2EE(JA ...

  7. alwaysOn中关于维护计划的应用方案

    由于alwaysOn环境下主副本所在的实际服务器不固定, 所以我目前采取的方案是创建维护计划的时候, 在各个服务器上创建一份维护计划. (假设有2个服务器需要故障转移, 那么就在这两个服务器上分别创建 ...

  8. Spring中Quartz的配置及corn表达式

    Quartz可以用来执行任务调度功能,如间隔一定时间调用执行任务.用起来还是蛮方便的.只要将你要调用的类配置到Spring配置文件即可. 在Spring的配置文件中配置Quartz. <!-- ...

  9. 07_jquery入门第一天

    视频来源:麦子学院 讲师:魏畅然 补充:JSON.stringify()函数 [https://www.cnblogs.com/damonlan/archive/2012/03/13/2394787. ...

  10. Hadoop-2.6.5安装

    简介 Hadoop是一个由Apache基金会所开发的分布式系统基础架构. 用户可以在不了解分布式底层细节的情况下,开发分布式程序.充分利用集群的威力进行高速运算和存储. Hadoop实现了一个分布式文 ...