从零开始学习前端JAVASCRIPT — 11、Ajax-前后端异步交互以及Promise-异步编程的改进
一、构造函数的使用
<!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="#">×</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-异步编程的改进的更多相关文章
- 从零开始学习前端JAVASCRIPT — 11、JavaScript运动模型及轮播图效果、放大镜效果、自适应瀑布流
未完待续...... 一.运动原理 通过连续不断的改变物体的位置,而发生移动变化. 使用setInterval实现. 匀速运动:速度值一直保持不变. 多物体同时运动:将定时器绑设置为对象的一个属性. ...
- 从零开始学习前端JAVASCRIPT — 14、闭包与继承
一.闭包 1 . 概念:闭包就是能够读取其他函数内部变量的函数.在JS中,只有函数内部的子函数才能读取局部变量,因此可以把闭包简单理解为”定义在一个函数内部的函数”. 2 . 闭包的特点 1)可以读取 ...
- ajax前后端数据交互简析
前端-------->后端 方法:POST 将要传递给后台的数据在前端拼接成url字符串,通过request.send()传递给后台,后台php把得到的数据以索引数组的方式存储在$_POST中. ...
- 从零开始学习前端JAVASCRIPT — 1、JavaScript基础
1:定义:javascript是一种弱类型.动态类型.解释型的脚本语言. 弱类型:类型检查不严格,偏向于容忍隐式类型转换. 强类型:类型检查严格,偏向于不容忍隐式类型转换. 动态类型:运行的时候执行类 ...
- 从零开始学习前端JAVASCRIPT — 10、JavaScript基础ES6(ECMAScript6.0)
ECMAScript 6.0(简称ES6)是JavaScript语言的下一代标准,已经在2015年6月正式发布了.它的目标,是使得JavaScript语言可以用来编写复杂的大型应用程序,成为企业级开发 ...
- 从零开始学习前端JAVASCRIPT — 7、JavaScript基础EVENT
1:事件驱动 1)事件:所谓事件就是js侦测到的用户的操作或是页面的一些行为(怎么发生的) 2)事件源对象:引发事件的元素.(发生在谁的身上) 3)事件处理程序:对事件处理的程序或是函数 (发生了什么 ...
- 从零开始学习前端开发 — 11、CSS3选择器
一.基本选择器 1.* 通配符(通用选择器) 2.id选择器 3.class选择器(类选择器) 4.标签选择器(元素选择符) 5.群组选择器 (选择符1,选择符2{...}) 二.层次选择器(关系选择 ...
- 从零开始学习前端JAVASCRIPT — 4、JavaScript基础Math和Date对象的介绍
Math对象的介绍 1:Math对象 Math 对象用于执行数学任务.并不像 Date 和 String 那样是对象的类,因此没有构造函数 Math().您无需创建它,通过把 Math 作为对象使用就 ...
- 从零开始学习前端JAVASCRIPT — 3、JavaScript基础string字符串介绍
1:字符串 JS中的任何数据类型都可以当作对象来看.所以string既是基本数据类型,又是对象. 2:声明字符串 基本数据类型:var sStr = '字符串'; 对象的方法:var oStr = n ...
随机推荐
- Hadoop问题:启动hadoop 2.6遇到的datanode启动不了
问题描述:第一次启动输入jps都有,第二次没有datanode 日志如下: 查看日志如下: -- ::, INFO org.mortbay.log: Started HttpServer2$Selec ...
- CCF系列之ISBN号码(201312-2)
试题名称: ISBN号码 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规 ...
- MyBatis 查询示例
环境搭建 数据库schema 1)datasource.xml配置 <?xml version="1.0" encoding="UTF-8"?> & ...
- socket编程--相关函数--sendto();read();
{1} 头文件:#include <sys/types.h> #include <sys/socket.h>定义函数:int sendto(int s, const voi ...
- mysql 存在索引但不能使用索引的典型场景
mysql 演示数据库:http://downloads.mysql.com/docs/sakila-db.zip 以%开头的LIKE查询不能够利用B-tree索引 explain select * ...
- 搞个小项目吧,做一个ppt播放器
先来两个参考链接,接下来再进行实战 http://www.geek-workshop.com/forum.php?mod=viewthread&tid=1137 http://www.geek ...
- Log4j源码解析--Layout类解析
本文转载上善若水的博客,原文出处:http://www.blogjava.net/DLevin/archive/2012/07/04/382131.html.感谢作者的分享. Layout负责将Log ...
- TP手册学习第一天
调试执行的sql语句 User::get(1); echo User::getLastSql(); 方法直接返回当前的查询SQL而不执行fetchSql echo User::fetchSql()-& ...
- PHP面试题超强总结(PHP中文网)
PHP面试基础题目 1.双引号和单引号的区别 双引号解释变量,单引号不解释变量 双引号里插入单引号,其中单引号里如果有变量的话,变量解释 双引号的变量名后面必须要有一个非数字.字母.下划线的特殊字符, ...
- C# 多线程复习笔记
编码的日子其实也有一段时间了,但是,作为一个客户端程序,因为自己是做游戏开发的,一直没有对线程这个概念比较模糊吧. 记录下线程的整理学习路线.原文:http://www.cnblogs.com/min ...