一、自定义对象的构造:

var student=new Object();  //object是顶级对象,使用构造函数的方法创建一个对象,此处的意思是创建了一个学生的空对象

student.name="李四";    

student.age="24";           //此处属性与方法是无序的

student.sex="男";
//这三句是函数的属性(姓名,年龄,性别) student.sayHi=function(){ console.log("我叫"+student.name+"我的年龄是"+student.age+"我是"+student.sex+"生"); };
//这句是函数的方法(问好) student.sayHi(); //最后可以通过对象名.方法名()调用这个函数。

我们可以通过构造函数的方法来创建一个对象。

function createstudent(name,age,sex){  //此处构造一个//createstudent的函数

    var student=new Object();  //创建一个学生对象

    student.name=name;       //分别给对象的属性赋一个形参

    student.age=age;

    student.sex=sex;

    student.sayHi=function(){   //此处为创建一个匿名函数将其赋给对象的方法,当最后调用这个匿名函数时执行此处代码。

        console.log("我叫"+student.name+"我的年龄是    "+student.age+"我是"+student.sex+"生");

    };

    return student;     //将对象返回出去

}

var lisi=createstudent("李四",20,"男");

lisi.sayHi();    

这里可以使用关键字this引用的是构造函数当前创建的对象。在这个方法中,this指向的所属的对象是最后用new所创建的Student对象。.

 
   function Student(name, age, sex) {

//(1)var student=new Object();   //(1)、(2)为冗余代码,因为每次调用都必须重新创建对象,并返回

        this.name = name;

        this.age = age;

        this.sex = sex;

        this.sayHi = function () {

            console.log("我叫" + this.name + "我的年龄是" + this.age + "我是" + this.sex + "生");

        };

// (2)   return student;

    }

    var lisi = new Student("李四", 20, "男");//此处创建一个对象

    lisi.sayHi();

new 的作用:

1)      先创建一个空对象;2)使用关键字this指向这个对象; 3)执行构造函数里面的代码,并给这个对象设置属性与方法;4)最后返回这个对象

二、对象的字面量:

对象的字面量大多用于只用一次的对象

其书写方式有两种:

第一种:

var o={};  

o.name="张三";

o.age=20;

o.sex="男";

o.sayHi=function(){

    console.log("我叫:"+ o.name+",我的年龄是:"+ o.age+",我是"+ o.sex+"生。");

};

o.sayHi();

第二种:

var o = {

    name: "张三",     //前面是键,后面是值,注意必须用逗号隔开

    age: 20,

    sex: "男",

    sayHi: function () {

        console.log("我叫:" + this.name + ",我的年龄是:" + this.age + ",我是" + this.sex + "生。");

    }                //最后不需要加逗号

};

  console.log(o.name);

  console.log(o.age);

o.sayHi();
//最后的输出方式也可以这样写
    
    console.log(o.["name"]);

    console.log(o.["age"]);
//这一种灵活一些,[]里面可以是属性也可以是变量

for…in

//for in
//获得对象之中每一个属性的值
for (var key in o) {

    console.log(key + "=======" + o[key]);

}

三.对于JSON对象的简单了解:

通过 jQuery AJAX,使用 HTTP Get 和 HTTP Post,您都可以从远程服务器请求 TXT、HTML、XML  或  JSON。

JSON主要用于与后台数据的传输。

var o = {                //json对象  主要用于传输数据

    "name": "张三",     //前面是键,后面是值,用逗号隔开

    "age": 20,           //JSON对象必须加上引号这也是与对象字面量定义属性与方法的区别。

    "sex": "男",

    "sayHi": function () {

        console.log("我叫:" + this.name + ",我的年龄是:" + this.age + ",我是" + this.sex + "生。");

    }

};

o.sayHi();

js学习-自定义函数、对象的字面量、json对象学习小结的更多相关文章

  1. js 正则学习小记之匹配字符串字面量优化篇

    昨天在<js 正则学习小记之匹配字符串字面量>谈到 个字符,除了第一个 个,只有 个转义( 个字符),所以 次,只有 次成功.这 次匹配失败,需要回溯后用 [^"] 才能匹配成功 ...

  2. JS常用自定义函数总结

    JS常用自定义函数总结   1.原生JavaScript实现字符串长度截取 2.原生JavaScript获取域名主机 3.原生JavaScript清除空格 4.原生JavaScript替换全部 5.原 ...

  3. 判读是不是对象字面量(纯对象)。对象字面量创建方式有{}、new Object()创建

    //判读是否是自身属性 function isHasPro(obj,pro){ return obj.hasOwnProperty(pro) ? true : false; } //判读是不是对象字面 ...

  4. js之字面量、对象字面量的访问、关键字in的用法

    一:字面量含义 字面量表示如何表达这个值,一般除去表达式,给变量赋值时,等号右边都可以认为是字面量. 字面量分为字符串字面量(string literal ).数组字面量(array literal) ...

  5. 学习熟悉箭头函数, 类, 模板字面量, let和const声明

    箭头函数:https://blog.csdn.net/qq_30100043/article/details/53396517 类:https://blog.csdn.net/pcaxb/articl ...

  6. 创建对象的两种方法: new 和 面向对象(对象字面量)及对象属性访问方法

    创建对象的两种方法: new 和 面向对象(对象字面量)用 new 时:var o = new Object();o.name = "lin3615";alert(o.name); ...

  7. Swift编程语言学习1.4——数值型字面量、数值类型转换

    数值型字面量 整数字面量能够被写作: 一个十进制数,没有前缀 一个二进制数,前缀是0b 一个八进制数,前缀是0o 一个十六进制数,前缀是0x 以下的全部整数字面量的十进制值都是17: let deci ...

  8. js 根本没有“JSON对象”这回事! JSON对象——转

    前言 写这篇文章的目的是经常看到开发人员说:把字符串转化为JSON对象,把JSON对象转化成字符串等类似的话题,所以把之前收藏的一篇老外的文章整理翻译了一下,供大家讨论,如有错误,请大家指出,多谢. ...

  9. 使用Gson将对象类转成Json对象时出现\u003d的问题

    Gson将对象转成Json对象的方法 Gson gson=new Gson(); String json=gson.toJson(Student.class); 这种情况,如果Student属性中的某 ...

随机推荐

  1. 炉石复盘 宇宙法vs复活牧 [20161130]

    选宇宙法完成使用50个法师职业牌的任务,遇到一个复活牧泰兰德. 前中期下怪,解场.虽然宇宙法偏娱乐,但牧师节奏也比较慢,因此血线一度降到10血以下,但仍然不惧怕牧师斩杀. 9费牧师拍下伊瑟拉,解不掉, ...

  2. cocos2dx 2.0 CCScrollView的用法以及滑动的原理

    #ifndef __HELLOWORLD_SCENE_H__ #define __HELLOWORLD_SCENE_H__ #include "cocos2d.h" USING_N ...

  3. Dynamics Webservice Call with Credential

    Dynamics Webservice call with credential /// <summary> ///WebServiceHelper 的摘要说明 /// </summ ...

  4. 使用JDBC处理Oracle大数据

    一.Oracle中大数据处理 在Oracle中,LOB(Large Object,大型对象)类型的字段现在用得越来越多了.因为这种类型的字段,容量大(最多能容纳4GB的数据),且一个表中可以有多个这种 ...

  5. java泛型中的super和extend

    List<? extend Fruit> list=new ArrayList<>();  解释为:集合中元素是继承自Fruit,究竟是何种类型,编译器也无法判定. 如果要从集 ...

  6. [转载]: delphi中XLSReadWrite控件的使用(1)---简介

    XLSReadWrite控件简介: 一个你需要的,能在Delphi和.NET下访问Excel文件的完美解决方案. 一个经典的读写Excel的控件,对于使用Excel 开发很有帮助 官方网站: http ...

  7. display:inline-block左右元素上下不对齐

    今天做了两个inline-block元素,出现左右两个元素顶端出现上下不对齐的情况(下图): 解决办法: 把应用 inline-block的元素加上 vertical-align: top; .CSS ...

  8. zedboard如何从PL端控制DDR读写(五)

    有了前面的一堆铺垫.现在终于开始正式准备读写DDR了,开发环境:VIVADO2014.2 + SDK. 一.首先要想在PL端通过AXI去控制DDR,我们必须要有一个AXI master,由于是测试,就 ...

  9. SQLite数据库文件格式

    数据库命名约定 sqlite3_open()API用到数据库的文件名,可以是相对当前工作目录的相对路径名,也可以是从系统根文件树开始的完整路径名.任何被本地文件系统接受的正规文件名都是好的. 如果文件 ...

  10. AtomicInteger

    原子量和普通变量相比,主要体现在读写的线程安全上.对原子量的写是原子的,由CAS操作保证原子性.对原子量的读可以读到最新值,由volatile关键字来保证可见性. ublic class Atomic ...