javascript 对象

1.基于对象

  一切皆对象,以对象的概念来编程

2.面向对象的编程(oop,Object oriented programming)

  1.对象

  就是人们要研究的任何事物,不仅能表示具体事物。对象的规则,计划或事件

  属性的无序集合,每个属性可以存一个值(原始值,)

  2,对象的属性和行为

  属性:用数据值来描述他的状态

  方法:用来改变对象行为的方法

  3类

  具有相同或相似的性质的对象的抽象就是类,对象的类的具体化(实例化) 就叫做对象

  var diannao=‘’;//声明的是字符串

  var diannao=[];//声明的是数组

  var diannao={};//声明的是对象

//javascript对象创建,

  在对象里面属性(变量),方法(函数)之间都是要逗号隔开,不能用分号

var mac = { pingpai: '苹果笔记本', price: '10000元', color: '白色', qq:function () { alert( '能聊天' ) }, game:function () { alert('能玩游戏')} };

//直接调用属性
alert( mac.pingpai );

//函数不能直接alert.
mac.qq();

 //javascript对象创建,
//对象就是一堆变量和函数的集合体
//原生形式创建对象,json数据格式
var mac = {
pinpai: '苹果笔记本',
price: '10000元',
color: '白色',
qq: function () {
alert( '能聊天' )
},
game: function () {
alert( '能玩游戏' )
}
}; //直接调用属性
alert( mac.pinpai );
//还可以有以下的方式
alert( mac['pinpai'] ); //调用函数不能直接alert.
mac.qq();
mac['qq'](); //添加属性方法
mac.size = '16英寸';
mac.work = function () {
alert('办公');
}; //删除属性(变量)和方法(函数)
delete mac.color;
alert('苹果笔记本颜色'+mac.color);

  

  

创建声明对象

  对象可以随时删除和添加变量和函数

  1,json方法(javascript object notation)原生格式

    var obj={};

    json是一种数据格式

    其实json类型的数据可以传回一个整体的数据,是属性名:值类型,如果想要获取数据的话,就直接obj点的形式读取

    例子:网站请求---》数据库端查询----》查询出所有结果返回一个json格式----》用obj接收之后----》再选取适合的数据

      var obj={name:'准求的完美',age:{18},sex:'爷们'}

      alert(obj.name);

  2,构造函数的方法:

    function fun1(){

      this.name='名字';

    }

  3,Object方法

    var obj=new Object();

添加属性和方法

  如果属性的值是函数,我们叫做他是对象的方法 属性

  构造方法

    1,声明的时候添加

    2,声明以后再添加

  json方法

    1.声明的时候添加

      var obj={属性名:属性值,属性名2:属性值2,属性名3:属性值3,.......};

    2.声明以后再添加

  

对象属性的遍历

  for(var i in Object){

    Object[i]

  }

//遍历对象
//x就像是爬虫一样,遍历mac的所有变量和函数
for ( x in mac ) {
document.write( x + '=>' + mac[x] + '<br/>' );
}

  

javascript数组对象

方法

直接对数组进行操作

1删除或添加类

  1,,数组对象.push(数组元素.....)

    向数组的末尾添加新的元素,返回值是新数组的长度,可以一次添加多个元素

  2,数组对象.unshift(数组元素....)

    向数组的开头加入新的元素,返回值是新数组的长度,可以一次添加多个元素

  3,数组对象.pop()

    删除数组的最后一个元素,返回删除的元素

  4,数组对象.shift()

    删除数组的第一个元素,返回删除的元素

  5,万能的添加删除函数(用于插入,删除或者替换数组的元素。)

   数组元素.splice(起始位置,数量,添加的元素.....)

    (1)起始位置   从何处开始添加或删除,必须是数值类型(数组的下标)

    (2)数量        规定了删除的个数,如果是0,则不删除

    (3)需要添加的元素 ,可以当做替换的元素

    (4)如果从数组中删除了元素,则返回的是含有被删除的元素

不直接改变数组,产生新的结果

数组的转换

  数组.join(['分隔符'])

  把数组元素按照指定分隔符组成一个字符串,如果没有指定分隔符。默认是用“,”返回结果就是组合成的字符串

 var shuiguo = new Array( '苹果', '香蕉', '鸭梨', '火龙果', '西瓜', '葡萄', '蛇皮果' );
//将数组转换成字符串
var re = shuiguo.join( '&' );
document.write(re);

  

数组分隔

  数组。slice()包含开始,不包含结束

  从截取指定的开始位置,到结束位置(不包括)如果不指定结束位置,一直截取到最后,则从指定的开始位置的(数组的下标)

支持负数(-1开头)

返回新的数组

 //数组截取
var shuiguo = new Array( '苹果', '香蕉', '鸭梨', '火龙果', '西瓜', '葡萄', '蛇皮果' ); //从什么位置开始截取
var re = shuiguo.slice( 0, 3 );
document.write(re);

属性

1.length

  设置或返回数组元素的数目

Math对象(数学对象)

  取绝对值

    Math.abs(-6);

  四舍五入

    Math.round(2.5);

  向上取整

    var re=Math.ceil(2.35);

  向下取整

    var re=Math.floor(2.956);

  取随机数。(无限接近于0.无限接近于1)

    Math.random();

    取X到Y之间的随机数:Math。random()*(y-x)+x;

    取随机整数:Math.floor(Math.random()*(y+1-X)+x)

      在0-5之间随机数

        Math.random()*5;

      在10-15之间的随机数

        Math.random()*5+10;

1,练习自定义一个函数(删除数组的重复元素)

['a','d','c','c','b','h','y','h','h']

2.随机点名

3.30选7彩票抽奖效果

js基础知识之_对象的更多相关文章

  1. js基础知识之_入门变量和运算符

    js页面效果学习 (轮播图,文字滚动效果等等) javascript能来做什么 1.数据验证 2.将动态的内容写入网页中(ajax) 3.可以对时间做出响应 4.可以读写html中的内容 5.可以检测 ...

  2. js基础知识之_函数

    javascript函数 函数概念 将完成某一特定功能的代码集合起来,可以重复使用 白话函数理解-函数就是一个工厂,帮大家实现某一个功能 优点 -时程序更加简洁 -逻辑更有条例 -调用方便 -维护更加 ...

  3. js基础知识之_流程控制语句

    javascript 流程控制 流程控制:就是程序代码执行顺序 流程控制:通过规定的语句让程序代码有条件的按照一定的方式执行 顺序结构 按照书写顺序来执行,是程序中最基本的流程结构 选择结构(分支结构 ...

  4. Js基础知识7-Es6新增对象Map和set数据结构

    前言 JavaScript中对象的本质是键值对的集合,ES5中的数据结构,主要是用Array和Object,但是键只能是字符串.为了弥补这种缺憾,ES6带来了一种新的数据结构Map. Map也是键值对 ...

  5. [JS复习] JS 基础知识

    项目结尾,空闲时间,又把<JS 基础知识> 这本书过了一遍,温故知新后,很多知其然不知其所以然的内容 豁然开朗. [1. 用于范围的标签] display  :inline or bloc ...

  6. NodeJs>------->>第三章:Node.js基础知识

    第三章:Node.js基础知识 一:Node.js中的控制台 1:console.log.console.info  方法 console.log(" node app1.js 1> ...

  7. JS基础知识笔记

    2020-04-15 JS基础知识笔记 // new Boolean()传入的值与if判断一样 var test=new Boolean(); console.log(test); // false ...

  8. HTML+CSS+JS基础知识

    HTML+CSS+JS基础知识 目录 对HTML+CSS+JS的理解 基础知识 对HTML+CSS+JS的理解 基础知识 插入样式表的三种方式 外部样式表:<link rel="sty ...

  9. Node.js基础知识

    Node.js入门   Node.js     Node.js是一套用来编写高性能网络服务器的JavaScript工具包,一系列的变化由此开始.比较独特的是,Node.js会假设在POSIX环境下运行 ...

随机推荐

  1. BZOJ_1015_星球大战_[JSOI2008]_(并查集)

    描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1015 n 个点,被 m 条边相连.进行k次删点操作,问第一次操作前和每次操作后的集合数(直接或 ...

  2. JS思维导图

  3. Android稳定性测试之Log分析

    做手机自动化测试已经快两年了,很久没写Blog了.今天抽空总结一下. 用自动化做稳定性测试,主要是为了发现系统或者应用出现FC/ ANR/ Reboot/ Freeze等问题. 先详细说下各种问题对应 ...

  4. Linux Mono OpenShift Cloud9 rhc

    OpenShift Mono Asp.net MVC4 MySql 1..Net4.0+Mvc4,不要使用太新的.Net4.5.1+Mvc5. 2.MySql数据库:MySql.Data.Dll 从官 ...

  5. 洛谷1377 M国王 (SCOI2005互不侵犯King)

    洛谷1377 M国王 (SCOI2005互不侵犯King) 本题地址:http://www.luogu.org/problem/show?pid=1377 题目描述 天天都是n皇后,多么无聊啊.我们来 ...

  6. JavaScript高级程序设计48.pdf

    设备中的键盘事件 任天堂Wii等设备可以通过键码知道用户按下了哪个键 复合事件 复合事件是DOM3级事件新添加的一类事件,用于处理IME的输入序列.IME(Input Method Editor,输入 ...

  7. Kth Ancestor 第k个祖先问题

    题目出处 这道题目出自hackerrank的8月月赛的第三题. 题目大意: 先给出一棵树 之后有三种操作分别为:加边,查询,和删除一个节点 查询的时候要给出任意节点x的第k个祖先 每组数据有t个cas ...

  8. Morris Traversal 二叉树遍历。

    那天做了个SWAP NODE的题,要求constant space,不得不Morris Traversal. 稍微研究了一下,真正意义上的O(1)space对二叉树进行遍历.好像是1979年的算法. ...

  9. [课堂实践与项目]手机QQ客户端--4期(SQLite的加入,注册,找回,登录界面的修改):建立关于QQ注册类,使用SQLite进行存储,

    经过昨天下午和今天上午的不懈努力,终于通过了SQLite的学习. 我们现在这里定义一个有关SQLIte的封装类,便于我在后面的用户注册,用户密码找回,和登录界面的使用 1.首先我们看看我们建立的use ...

  10. WAMP不能启动MYSQL服务

    突然不知道怎么整的,就把wamp的mysql服务整个不能启动,忧桑. 点击重启Mysql服务: PHP集成环境WAMP中MYSQL的服务wampmysqld无法启动,总是提示 错误1067:进程意外终 ...