[自定义对象]
1.基本概念
①对象是包含一系列无序属性和方法的集合;
②键值对:对象中的数据是以键值对的形式存在的,以键取值;
③属性:描述对象特征的一系列变量,【对象中的变量】
④方法:描述对象行为一系列方法【对象中的函数称为方法】
2.声明对象
  ①字面量声明:var obj= {
  key1:value1,//属性
  key2:value2,
  func:function(){},//方法
  }
  ②new关键字:var lisi=new Object(){
            lisi.name="李四";
         lisi.say=function(){
  console.log("我是:"+this.name);
         }
  对象中的键可以是任何数据类型;但一般用作普通变量名(不需要“”)即可;
       对象中的值可以是任何数据类型;但字符串的话,必须用“”包裹;
       多组键值对之间用英文逗号分隔,键值对的键与值之间用英文冒号分隔;
3.对象中属性和方法的读写:
①运算符:对象内部:this.属性名      this.方法名()
                    对象外部:对象名.属性名    对象名.方法名()
②通过["key"]调用,对象名["属性名"] 对象名["方法名"]();
  >>如果key中包含特殊字符,则无法使用第一种方式,必须使用第二中
  >>对象中,直接写变量名,默认为调用全局变量,如果需调用对象自身属性,则需要使用this关键字;
  ③删除对象的属性方法:delete.对象名.属性/方法;
            (栗子) 杨辉三角:
 
                                 【内置对象】
 引用数据类型:数组和对象(两个引用指向同一内存空间地址)
值类型:不同变量分配不同的存储空间;
【js中的数组】
1.数组的概念:是在内存中连续储存的多个有序元素的结构,元素的顺序称为下标;通过下表查找对应元素;
2.数组的声明:
   ①.字面量声明:var arr1=[,,,,];
   js中可以储存多种不同的数据类型,一般同一数组只用于存放统一数据类型;
例如:var arr1=[1,"2",true,{"name":"shuai"},[1,2]];(一般不建议使用);
   ②.new 关键字声明:var arr2=new Array( );
   参数可以为:
  a:空,声明一个没有指定长度的数组;
  b:数组的length:声明一个指定长度的数组,但是数组的长度随时可便可追加;最大长度为0-(2^32-1)
          c:数组默认的n个值:var arr2=new Array(1,"2",true);相当于[1,,"2",true];
3.数组中元素的读写/增删:
   ①读写:通过下标来访问元素:例如arr[2];
   ②增删:delete arr4[n];删除数组的第n+1个值,数组长度不变,对应位置为undefined;
      arr4.push(值),数组最后增加一个值,arr3[arr3.length]=7;
      arr4.unshift(值):数组的第0位插入一个值,其余数位顺延;
      arr4.pop():删除数组最后一位,与delete不同的是,pop执行后数组长度也会减少一个,相当于arr3.length-=1;
      arr4.shift();删除数组第0位,长度也会减一;
4.数组中其他常用方法:
arr3.join("分隔符号"),将数组指定分隔符符号分隔,链接为字符串,参数为空时,默认为逗号分隔;
concat();将数组与多个数组的值链接为新的数组;
[1,2].concat([3,4][5,6])=[1,2,3,4,5,6];连接时,中括号最多拆一层;
[1,2].concat([1,2,[3,4])=[1,2,1,2,[3,4]];多层中括号内,以二维数组形式存在;
push:数组最后增加一个数;unshift:数组开始增加一个数;两者返回数组新的长度;
  pop():删除数组最后一个;shift()删除数组第一个;两者返回被删掉的值;
  var num=push();
arr4.reverse();【原数组被改变】数组翻转,你序排列;
slice(begin,end):[原数组不会被改变]截取数组中的一部分,成为新数组;
  >>>传递一个参数,默认为begin index,当这个开始,截到最后一个;
  >>>两个数的区间(包含begin,不含end),基本是左闭右开。
  >>> 参数可以为负数,-1表示最后一个;
sort(function):[原数组会改变]:对数组进行排序;
    >>不指定函数排序,按照数值的AScII值进行排列;
    >>传入排序函数,默认两个参数a,b;如果函数返回值>0;a>b;
    >> return a-b;升序排列,a在后,b在前;//升序排列,两两比对,谁大谁放后面
    >> return b-a;a在前,b在后;
  indexOf(value,index):返回数组中第一个value值对应的索引位置。若未找到,返回-1;
  lastIndexOf(value,index):返回数组中最后一个value值对应的索引位置。若未找到,返回-1;
  【注意】:若未指定index参数:默认在数组所有元素中查询;若指定index参数,则从当前index开始向后查询;
5.二维数组&稀疏数组(了解);
  》》稀疏数组:数组并不含有从0开始到length-1的所有索引(length值实际比元素的个数多);
   二维数组[var arr7=[[1,2,3] [4,5,6] [7,8,9][0,1,2]];]
  去除二维数组的元素,arr[行号][列好];//使用循环 遍历;
6. 引用数据类型:数组和对象,赋值时就是将原变量的地址赋给新变量,两个变量实际操作同一份数据,所以,修改其中一个变量 ,另一边量也会跟着变化;
    基本数据类型:赋值时,赋值时就是将原变量的值赋给新变量,两个变量属于不同的内存空间,修改其中一个互不干扰。
Boolean类
var isTrue = true; // 单纯的变量
var isTrue1 = new Boolean(true); // 一个Boolean类型的对象
Number类
  Number.MIN_VALUE 可表示的最小数
  Number.MAX_VALUE 可表示的最大数
  .toString():将数字转为字符串,相当于 num+""
  .toFixed(n):将数字转为字符串,保留n位小数,四舍五入
  .valueOf():返回Number对象的基本数字值
  .toLocaleString():将数字按照本地格式的顺序转为字符串。一般,三个一组加逗号
  .toPrecision(n):将数字格式化为指定长度,n=不含小数点的所有位数和
  字符串String
1、属性:str.length 返回字符串的长度;
2、方法:
.toLowerCase() 所有字符转为小写;
.toUpperCase() 所有字符转为大写;
.charAt(n) 截取字符串中第n个字符
.indexOf("查询子串",index) 查询从index开始的,第一个子串的索引。没找到返回-1,同数组的indexOf()方法;
.substring(begin,end) 截取子串
>>> 只写一个参数:从begin开始,到最后
  >>> 写两个参数:从begin开始,到end。左闭右开。
    .replace("old","new") 将字符串中,第一个old,替换为new。第一个参数可以为普通字符串,也可以为正则表达式(普通字符串将只匹配第一个,正则表达式则根据具体情况区分)。
.split("") 将字符串,通过制定分隔符分为数组。传入""空字符串,将把单个字符存入数组
    Date类
  1、 new Date(); 拿到当前最新时间;
      new Date("2017,4,4,14:58:12")  设置指定时间
  2、常用方法:
     .getFullYear(): 获取4位年份
     .getMonth(): 获取月份 0~11
     .getDate(): 获取一月中的某一天 1~31
     .getDay(): 获取一周中的某一天 0~6
     .getHours() 返回 Date 对象的小时 (0 ~ 23)
     .getMinutes() 返回 Date 对象的分钟 (0 ~ 59)
     .getSeconds() 返回 Date 对象的秒数 (0 ~ 59)
 
 
 

详解JS对象的更多相关文章

  1. js对象详解(JavaScript对象深度剖析,深度理解js对象)

    js对象详解(JavaScript对象深度剖析,深度理解js对象) 这算是酝酿很久的一篇文章了. JavaScript作为一个基于对象(没有类的概念)的语言,从入门到精通到放弃一直会被对象这个问题围绕 ...

  2. 详解js变量、作用域及内存

    详解js变量.作用域及内存 来源:伯乐在线 作者:trigkit4       原文出处: trigkit4    基本类型值有:undefined,NUll,Boolean,Number和Strin ...

  3. dom对象详解--document对象(二)

       dom对象详解--style对象 style对象 style对象和document对象下的集合对象styleSheets有关系,styleSheets是文档中所有style对象的集合,这里讲解的 ...

  4. [转]javascript console 函数详解 js开发调试的利器

    javascript console 函数详解 js开发调试的利器   分步阅读 Console 是用于显示 JS和 DOM 对象信息的单独窗口.并且向 JS 中注入1个 console 对象,使用该 ...

  5. 详解js和jquery里的this关键字

    详解js和jquery里的this关键字 js中的this 我们要记住:this永远指向函数运行时所在的对象!而不是函数被创建时所在的对象.this对象是在运行时基于函数的执行环境绑定的,在全局环境中 ...

  6. 详解js面向对象编程

    转自:http://segmentfault.com/a/1190000000713346 基本概念 ECMA关于对象的定义是:”无序属性的集合,其属性可以包含基本值.对象或者函数.“对象的每个属性或 ...

  7. dom对象详解--document对象(一)

     document对象 Document对象代表整个html文档,可用来访问页面中的所有元素,是最复杂的一个dom对象,可以说是学习好dom编程的关键所在. Document对象是window对象的一 ...

  8. Struts功能详解——ActionMapping对象

    Struts功能详解——ActionMapping对象 ActionMapping描述了struts中用户请求路径和Action的映射关系,在struts中每个ActionMapping都是通过pat ...

  9. php开发面试题---php面向对象详解(对象的主要三个特性)

    php开发面试题---php面向对象详解(对象的主要三个特性) 一.总结 一句话总结: 对象的行为:可以对 对象施加那些操作,开灯,关灯就是行为. 对象的形态:当施加那些方法是对象如何响应,颜色,尺寸 ...

随机推荐

  1. oracle备份脚本

    利用EXP导出全库,必须用SYSTEM或者DBA用户来导出. 具体脚本实现如下 全库导出(fullbackup): #!/bin/bash bname=`date +%Y%m%d` cd /backu ...

  2. CoreCLR源码探索(五) GC内存收集器的内部实现 调试篇

    在上一篇中我分析了CoreCLR中GC的内部处理, 在这一篇我将使用LLDB实际跟踪CoreCLR中GC,关于如何使用LLDB调试CoreCLR的介绍可以看: 微软官方的文档,地址 我在第3篇中的介绍 ...

  3. java封装的方法

    java封装是由Java是面向对象程序设计语言的性质决定的,面向对象程序设计语言的三大特性之一就是封装.封装其实就是包装的意思,从专业的角度来看,就是把对象的所有组成部分组合在一起,保护私有属性. 如 ...

  4. python之字符串

    字符串与文本操作 字符串: Python 2和Python 3最大的差别就在于字符串 Python 2中字符串是byte的有序序列 Python 3中字符串是unicode的有序序列 字符串是不可变的 ...

  5. MVC特性路由的提供机制

    回顾:传统路由是如何提供的? 我们知道最终匹配的路由数据是保存在RouteData中的,而RouteData通常又是封装在RequestContext中的,他们是在哪里被创建的呢?没错,回到了UrlR ...

  6. 转接IC整理汇总 转接芯片大全

    转接口IC大全,信号转换大全EDP输出信号NCS8801 LVDS转EDP.RGB转EDP 封装QFN56 最大分辨率2560*1600用于手机.平板.转接板.液晶驱动板.广告机.可视门铃等等控制器到 ...

  7. H5学习的第三周

    上周,我们结束了京东站的制作,本周我们开始了手机站和响应式网站的学习,并仿制了一个手机端界面和一个响应式界面,在完成这两个网站的过程中我遇到了许多问题,也了解了它们的解决方法,接下来我讲详细介绍本周我 ...

  8. kindeditor扩展粘贴图片功能&修改图片上传路径并通过webapi上传图片到图片服务器

    前言 kindeditor是一个非常好用的富文本编辑器,它的简单使用我就不再介绍了. 而kindeditor却对图片的处理不够理想. 本篇博文需要解决的问题有两个: kindeditor扩展粘贴图片功 ...

  9. linux常用20命令 --转载

    玩过Linux的人都会知道,Linux中的命令的确是非常多,但是玩过Linux的人也从来不会因为Linux的命令如此之多而烦恼,因为我们只需要掌握我们最常用的命令就可以了.当然你也可以在使用时去找一下 ...

  10. STAR法则的感想

    STAR法则百度百科上被解释为,面试官用于收集面试者信息的工具,而我个人理解,它更像是一个表达技巧,叙述结构,我们先来看看什么是STAR法则: STAR法则,即为Situation Task Acti ...