20150206--JS巩固与加强4-02

20150206--JS巩固与加强4-02

五、属性遍历与删除

1、使用for…in…遍历自定义对象属性

基本语法:

for…in…(主要是完成对对象的遍历)

示例代码:

clip_image002

运行效果:

clip_image004

说明:在17行代码,不能使用p1.i形式进行自定义对象属性的遍历,否则会弹出undefined,原因是因为当代码识别到p1对象会认为p1.i是访问p1对象的i属性,由于没有定义i属性,所以系统会弹出3个undefined。

2、使用for…in…结构实现系统对象的遍历

window

document

示例代码:

clip_image006

运行效果:

clip_image008

3、属性删除操作

在Javascript,有时我们可能并不需要某个对象的某个属性,这个时候我们可以采用delete关键词实现对自定义属性的删除操作

基本语法:

delete对象.属性

删除指定属性

示例代码:

clip_image010

运行效果:

clip_image012

六、成员方法

1、基本语法:

对象.属性 = 函数的首地址

例1:为对象添加speak说话方法

clip_image014

例2:创建对象p2,为p2添加speak说话方法

clip_image016

观察以上代码,与例1中的p1对象的成员方法完全一致,似乎代码出现了重叠,改进上题

例3:改进上题

clip_image018

例4:由于以上代码有很多重复性的代码,那么我们可以对以上代码进行封装

clip_image020

七、json对象

1、什么是json

对象是指属性的无序集合

所谓“集合”是指名/值对的集合,名/值对之间是通过 ,逗号隔开的

在js中,可以使用{}来表示这个集合

2、基本语法

var 变量 ={};

第一种:{‘属性’:’属性的值’, ‘属性’:’属性的值’, ‘属性’:’属性的值’}

第二种:{“属性”:”属性的值”, “属性”:”属性的值”, “属性”:”属性的值”}

第三种:{属性:’属性的值’,属性:’属性的值’,属性:’属性的值’,}

3、快速入门

例1:通过json对象描述一个人的信息

clip_image022

4、json对象从“何”而来

clip_image024

通过以上代码可以证明:

json对象是Object类的一个实例,其实在Javascript中,Object类是所有类的基类,所有的对象都继承了Object类的属性。

json对象主要用于大批量数据的保存

例2:通过json对象保存多个人的信息

clip_image026

5、php与json

在php提供了两个生成与解析json格式的函数

json_encode(数组或对象)

数组通常采用关联性数组

json_decode(json格式字符串)

ajax xml

ajaj json

1)把数组转化为json格式的数据

clip_image028

2 )把对象转换成json格式的数据

clip_image030

说明:在json_encode函数中,目前只支持UTF-8,如果是GBK或GB2312请通过iconv进行转化,否则无法使用或无法得到正常数据

3)把二维数组转化为json格式数据

clip_image032

4)json_decode代码解析

json_decode($json对象,[bool])

功能:把json格式数据反转化

参数说明:

第一个参数是json格式数据

第二个参数是布尔类型的值,如果为true,则返回array数组类型的数据,如果是false或不填写,则直接返回stdClass类的实例(对象)

clip_image034

clip_image036

不加true参数效果

clip_image038

clip_image040

案例:通过php+json完成对历史上的今天api接口调用

http://www.juhe.cn/聚合数据

clip_image042

clip_image044

a)复制url地址http://japi.juhe.cn/toh/toh?key=您申请的KEY&v=1.0&month=11&day=1

参数说明

key:密钥

v:版本1.0

month:月份

day:天

b)通过接口可知,其属于get请求

clip_image046

效果如下:

clip_image048

6、为json对象添加成员方法

clip_image050

运行效果:

clip_image052

八、原型链

1、什么是原型对象?

答:当系统加载构造器时,系统会自动生成一个对象,我们把这个对象就称之为原型对象。

构造器与原型对象在内存中是相互独立的,但是其还有联系:

在构造器中存在一个prototype属性,指向原型对象

原型对象也存在属性指向构造器

clip_image054

2、原型对象作用?

当构造器的实例访问一个不存在的属性时,系统会自动到构造器的原型对象中去寻找,如找到则直接使用。

clip_image056

当我们在某些已存在的框架或对象中找不到我们想要属性或方法,我们可以借助原型对象,把需要的属性或方法追加到原型对象。

3、如何向原型对象中添加属性或方法

构造器.prototype.属性=属性的值

clip_image058

clip_image060

4、探讨:原型对象到底从何而来

说明:当系统创建原型对象,系统会自动执行以下代码

构造器.prototype = new Object();

由于原型对象都是Object类的实例,那么根据面向对象原则,我们的原型对象会自动继承Object类中属性和方法。

示例代码:

clip_image062

说明:当我们运行到第14行,系统自动访问p1对象的hasOwnPropery属性,但由于系统中并不存在hasOwnProperty属性,所以会到Person构造器的原型对象中去寻找,没有找到,又由于所有的原型对象都是Object类的实例,所以原型对象会自动继承Object类下面的所有的属性和方法,所以发现该行代码正常执行,原理图如下:

clip_image064

我们把以上情况就称之为原型继承,通过以上图解也可以证明,Object类是所有类的基类。

clip_image066

说明:在Javascript中,当某一个对象引用一个不存在属性或方法时,系统首先到当前构造器的原型对象中去寻找,如还找不到,其会到上一层原型对象中去寻找,直至Object原型对象,我们把这种链接查找关系就称之为原型链。

作业:扩展数组类的功能:(Array)

为每一个数组对象添加一个方法,可以查找某个元素的所在位置

var arr = [10,20,30,40,50];

arr.find(40);

2、扩展数字类的功能(Number)

为一个数字对象添加一个方法,该方法的参数为任意数目的整数,然后将所有参数累加到一起,并返回总和

vari = 10;

i.sum(10,30,40,50,60,60);

posted on 2016-05-05 23:59 山山未迟 阅读(...) 评论(...) 编辑 收藏

转载于:https://www.cnblogs.com/lifushan/p/5463893.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/257234.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

面向对象课程 - T-shirt

拿到了一件谜一样的T-shirt 吓得我赶紧捏了下hbb 转载于:https://www.cnblogs.com/andwho/p/5465165.html

状态开关(ToggleButton)

状态开关(ToggleButton): 常用属性:isChecked(是否被选中,如true) 监听:1.监听方法:setOnCheckedChangeListener 2.监听器:CompoundButton.OnCheckedChangeLi…

冲刺第二阶段

转载于:https://www.cnblogs.com/lixin20/p/4549338.html

微信消息推送服务器吗,消息推送

# 消息推送接入微信小程序消息推送服务,可以两种方式选择其一:# 开发者服务器接收消息推送开发者需要按照如下步骤完成: 填写服务器配置验证服务器地址的有效性据接口文档实现业务逻辑,接收消息和事件# 第一步:填写服务…

windows下eclipse远程连接hadoop集群开发mapreduce

转载请注明出处,谢谢2017-10-22 17:14:09之前都是用python开发maprduce程序的,今天试了在windows下通过eclipse java开发,在开发前先搭建开发环境。在此,总结这个过程,希望能够帮助有需要的朋友。用Hadoop eclipse plu…

20145308刘昊阳 《Java程序设计》实验五报告

20145308刘昊阳 《Java程序设计》实验五 Java网络编程及安全 实验报告 实验名称 Java网络编程及安全 实验内容 1.掌握Socket程序的编写; 2.掌握密码技术的使用; 3.设计安全传输系统。 统计的PSP(Personal Software Pro…

FPL 2017最佳论文:如何对FPGA云发动DoS攻击?

第27届现场可编程逻辑与应用国际会议(The International Conference on Field-Programmable Logic and Applications,FPL)九月份在比利时根特召开。在FPL 2017上,一篇来自德国卡尔斯鲁厄理工学院(Karlsruhe Institute …

BZOJ 1692: [Usaco2007 Dec]队列变换( 贪心 )

数据 n < 30000 , 然后 O( n ) 的贪心也过了..... USACO 数据是有多弱啊 ( ps : BZOJ 1640 和此题一模一样 , 双倍经验 ) --------------------------------------------------------------------------------------#include<cstdio>#include<cstring>#include…

数据说话,88000条数据绘制北京市地图

偶获得一批数据&#xff0c;本着好玩的态度绘制下来看看到底是什么鬼&#xff0c;绘制的结果如下&#xff1a; 呵呵&#xff0c;什么都不像。而且中间最重要的部分因数据量过大绘制的已经看不清楚了。于是乎&#xff0c;缩小绘制范围&#xff0c;去除周围没有用的数据。重新绘制…

我的第一个python web开发框架(11)——工具函数包说明(二)

db_helper.py是数据库操作包&#xff0c;主要有两个函数&#xff0c;分别是read()数据库读操作函数和write()数据库写操作函数。这个包的代码是从小戴同学分享的博文改造过来的。 1 #!/usr/bin/env python2 # codingutf-83 4 import psycopg25 from common import log_helper6 …

linux crontab 命令

#method 1 crontab -e crontab -u root -e #不同用户自己的任务计划 crontab -l#method 2 vim /etc/crontab# Example of job definition: # .---------------- minute (0 - 59) # | .------------- hour (0 - 23) # | | .---------- day of month (1 - 31) # | | | .--…

【Swift学习】Swift编程之旅---ARC(二十)

Swift使用自动引用计数(ARC)来跟踪并管理应用使用的内存。大部分情况下&#xff0c;这意味着在Swift语言中&#xff0c;内存管理"仍然工作"&#xff0c;不需要自己去考虑内存管理的事情。当实例不再被使用时&#xff0c;ARC会自动释放这些类的实例所占用的内存。然而…

转:传入的表格格式数据流(TDS)远程过程调用(RPC)协议流不正确 .

近期在做淘宝客的项目&#xff0c;大家都知道&#xff0c;淘宝的商品详细描述字符长度很大&#xff0c;所以就导致了今天出现了一个问题 VS的报错是这样子的 ” 传入的表格格式数据流(TDS)远程过程调用(RPC)协议流不正确“ 还说某个desricption 过长之类的话 直觉告诉我&#…

合并bin文件-----带boot发布版本比较好用的bat(便捷版)

直接上图上代码&#xff08;代码在结尾&#xff09;&#xff0c;有不会用的可以留言&#xff1a; 第一步&#xff1a;工程介绍&#xff0c;关键点--- 1.bat文件放所在app和boot工程的同级目录下 2.release为运行bat自动生成文件夹 第二步&#xff1a;合版.bat 针对具体项目需…

关于cmake从GitHub上下载的源码启动时报错的问题

关于cmake从GitHub上下载的源码启动时报错的问题&#xff1a; 由于cmake会产生all_build和zero_check两个project&#xff0c;此时需要右击鼠标将需要运行的项目设为启动项&#xff0c;在进行编译&#xff0c;现只针对“找不到all_build文件“的出错信息&#xff0c;若有相关编…

Elementary OS安装Chrome

elementary os 官方网站&#xff1a;https://elementary.io/ 这os是真好看&#xff01;首先这是基于ubuntu的&#xff0c;所以可以安装ubuntu的软件&#xff01; 电脑必备浏览器必须是chrome呀&#xff01;下载地址&#xff1a; https://www.chrome64bit.com/index.php/google…

spark、oozie、yarn、hdfs、zookeeper、

为什么80%的码农都做不了架构师&#xff1f;>>> spark、 oozie:任务调度 yarn:资源调度 hdfs:分布式文件系统 zookeeper、 转载于:https://my.oschina.net/u/3709135/blog/1556661

JLOI2016 方

bzoj4558 真是一道非常excited的题目啊…JLOI有毒 题目大意&#xff1a;给一个(N1)*(M1)的网格图&#xff0c;格点坐标为(0~N,0~M)&#xff0c;现在挖去了K个点&#xff0c;求剩下多少个正方形&#xff08;需要注意的是正方形可以是斜着的&#xff0c;多斜都可以&#xff09; N…

opencv 直方图反向投影

转载至&#xff1a;http://www.cnblogs.com/zsb517/archive/2012/06/20/2556508.html 直方图反向投影式通过给定的直方图信息&#xff0c;在图像找到相应的像素分布区域&#xff0c;opencv提供两种算法&#xff0c;一个是基于像素的&#xff0c;一个是基于块的。 使用方法不写了…

request请求在Struts2中的处理步骤

2019独角兽企业重金招聘Python工程师标准>>> 一个请求在Struts2框架中的处理大概分为以下几个步骤 1 客户端初始化一个指向Servlet容器&#xff08;例如Tomcat&#xff09;的请求 2 这个请求经过一系列的过滤器&#xff08;Filter&#xff09;&#xff08;这些过滤…