当前位置: 首页> 科技> IT业 > JS(JavaScript)的复合类型详解

JS(JavaScript)的复合类型详解

时间:2025/7/12 14:45:43来源:https://blog.csdn.net/mo_sss/article/details/139829951 浏览次数:0次

天行健,君子以自强不息;地势坤,君子以厚德载物。


每个人都有惰性,但不断学习是好好生活的根本,共勉!


文章均为学习整理笔记,分享记录为主,如有错误请指正,共同学习进步。


一枝红艳露凝香,云雨巫山枉断肠。
借问汉宫谁得似,可怜飞燕倚新妆。
——《清平调三首·其二》


文章目录

  • JS(JavaScript)的复合类型详解
    • 1. String
      • 1.1 定义语法
      • 1.2 定义并赋值
      • 1.3 常用方法
      • 1.4 示例代码
    • 2. Date
      • 2.1 定义语法
        • 2.1.1 直接定义
        • 2.1.2 指定时间定义
        • 2.1.3 指定毫秒数定义
      • 2.2 常用方法
      • 2.3 示例代码
    • 3. JSON
      • 3.1 JSON简介
      • 3.2 基本语法
      • 3.3 JSON的使用
        • 3.3.1 简单json对象
        • 3.3.2 复合json对象
        • 3.3.3 json对象数组
      • 3.4 JSON 转换
        • 3.4.1 json转换为字符串
        • 3.4.2 字符串转为json对象
      • 3.5 示例代码
    • 4. 对象类型
      • 4.1 对象介绍
      • 4.2 创建对象
        • 4.2.1 使用Object创建对象
          • 4.2.1.1 语法
          • 4.2.1.2 示例
        • 4.2.2 使用构造函数创建对象
          • 4.2.2.1 语法
          • 4.2.2.2 示例
        • 4.2.3 使用JSON对象结构创建对象
          • 4.2.3.1 语法
          • 4.2.3.2 示例
      • 4.3 示例代码
    • 5. 示例代码下载


JS(JavaScript)学习专栏


JS(JavaScript)的复合类型详解

1. String

1.1 定义语法

string类型的定义语法如下

var str;

var str = new String();

1.2 定义并赋值

//基本数据类型
var str1 = " libai dufu ";

//引用数据类型
var str2 = new String("libai");

1.3 常用方法

string类型的常用方法如下表

方法描述
charAt()返回在指定索引位置的字符,也可以使用[索引]的方式
indexOf()返回某个指定的字符串值在字符串中首次出现的位置
lastIndexOf()返回某个指定的字符串值在字符串中最后出现的位置
toLowerCase()把字符串转化为小写
toUpperCase()把字符串转化为大写
substring()提取字符串中两个指定的索引号之间的字符,左开右闭,即左边包括,右边不包括
replace()将指定的字符串替换为指定的新的字符串
split()把字符串分割为字符串数组
trim()去除前后两端的空格

1.4 示例代码

常用方法的实力代码如下

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>复合类型-string</title><script>//基本数据类型var str1 = " libai dufu ";//引用数据类型var str2 = new String("libai");var length = str1.length;console.log("str1字符串长度获取.length: ",length);//charAt()console.log("str1索引为0的元素:",str1.charAt(0));console.log("str1索引为3的元素:",str1.charAt(3));console.log("str1索引为3的元素:",str1[3]);console.log("str1最后一个元素:",str1[str1.length-1]);console.log("str1最后一个元素:",str1.charAt(str1.length-1));console.log("返回str1字符串中首次出现i所在的索引:",str1.indexOf("i"));console.log("返回str1字符串中最后一次出现i所在的索引:",str1.lastIndexOf("i"));console.log("将str1字符串转为小写:",str1.toLowerCase());console.log("将str1字符串转为大写:",str1.toUpperCase());console.log("截取字符串索引1到3的内容:",str1.substring(1,3));console.log("将字符串中的空格换成大写的T:",str1.replace(" ","T"));console.log("将字符串以空格分隔成字符串数组:",str1.split(" "));console.log("剔除字符串前后的空格:",str1.trim());</script></head>
<body></body>
</html>

执行代码,浏览器控制台输出如下
在这里插入图片描述

2. Date

2.1 定义语法

定义日期的方法有三种

2.1.1 直接定义

直接定义当前时间的Date对象

//定义日期对象,表示当前时间
var date1 = new Date();
2.1.2 指定时间定义

指定时间的年月日时分秒来定义某个时间

//参数指定年月日时分秒
var date2 = new Date(2024,5,12,13,14,52);
2.1.3 指定毫秒数定义

指定毫秒值定义某个时间

//参数指定为与1970年1月1日零时零分相差的毫秒数
var date3 = new Date(1718690957162);

2.2 常用方法

Date对象的常用方法如下表

方法描述
getFullYear()以四位数字返回年份
getMonth()返回月份(-11),0表示1月
getDate()返回一个月中的某一天(1-31)
getHours()返回一个小时(0-23)
getMinutes()返回分钟(0-59)
getSeconds()返回秒(0-59)
getMilliseconds()返回毫秒(0-59)
getDay()返回一周中的某一天(0-6),0表示周日
getTime()返回从1970-1-1 0:0:0至今的毫秒数

set方法和get方法使用方法相同,用于设置值

方法描述
setFullYear()以四位数字设置年份
setMonth()设置月份(-11),0表示1月
setDate()设置一个月中的某一天(1-31)
setHours()设置一个小时(0-23)
setMinutes()设置分钟(0-59)
setSeconds()设置秒(0-59)
setMilliseconds()设置毫秒(0-59)
setDay()设置一周中的某一天(0-6),0表示周日
setTime()设置从1970-1-1 0:0:0至今的毫秒数

2.3 示例代码

相关get方法的操作示例代码如下

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>复合类型-date</title><script>//定义日期对象,表示当前时间var date1 = new Date();//参数指定年月日时分秒var date2 = new Date(2024,5,12,13,14,52);//参数指定为与1970年1月1日零时零分相差的毫秒数var date3 = new Date(1718690957162);console.log("当前时间date1:",date1);console.log("指定时间date:2:",date2);console.log("指定时间date3:",date3);var y = date1.getFullYear();console.log("当前的年:",y);var m = date1.getMonth();console.log("当前的月:",m);var d = date1.getDate();console.log("当前的日:",d);var h = date1.getHours();console.log("当前的小时:",h);var min = date1.getMinutes();console.log("当前的分钟:",min);var s = date1.getSeconds();console.log("当前的秒:",s);var ms = date1.getMilliseconds();console.log("当前的毫秒:",ms);var ls = date1.getTime();console.log("当前的时间距离1970年1月1日0点整的毫秒数:",ls);var day = date1.getDay();//返回的时间day是从0-6的数字,0表示周日,1表示周一,依次类推var weekday = ['周日','周一','周二','周三','周四','周五','周六']var currentTime = y+"年"+m+"月"+d+"日 "+h+":"+min+":"+s+":"+ms+" "+weekday[day];console.log("当前时间完整表示:", currentTime);document.write("网页上显示当前时间:",currentTime)</script></head>
<body></body>
</html>

执行代码后,浏览器控制台输出结果如下
在这里插入图片描述
浏览器网页输出
在这里插入图片描述

3. JSON

3.1 JSON简介

    json全称为JavaScript Object Notation是一种轻量级的数据交换格式,用于表示JavaScript对象的一种方式采用与编程语言无关的文本格式,易于阅读和编写,同时易于解析与生成

3.2 基本语法

json的语法格式如下

{"属性名":"属性值","属性名":"属性值",...}

注意:
json结构是由一系列的键值对组成,称为json对象
属性名必须使用双引号引起来

3.3 JSON的使用

json的使用有三种方式

  • 简单的json对象
  • 复合属性,属性值为json对象
  • json对象的集合
3.3.1 简单json对象

直接定义简单的json对象,如下

        var man = {"name":"dufu","age":29}
3.3.2 复合json对象

定义复合的json对象,即json中嵌套json,如下

        var man = {"name":"dufu","age":29,"address":{"provice":"shanghai","city":"shanghaic","district":"pudong"}}
3.3.3 json对象数组

定义json对象数组,如下

        var arrjs = [{"id":"1111","name":"libai"},{"id":"2345","name":"baijuyi"},{"id":"6778","name":"menhaoran"}];

3.4 JSON 转换

json和字符串之间的转换

3.4.1 json转换为字符串

json转换为字符串使用JSON.stringigy(json对象)方法

        //将json对象转为字符串var str1 = JSON.stringify(json对象);
3.4.2 字符串转为json对象

字符串转为json对象使用JSON.parse(字符串)方法

        var jsonObj = JSON.parse(字符串);

3.5 示例代码

关于json定义和转换的实力代码如下

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>复合类型-json</title><script>// 定义json对象var man = {"name":"dufu","age":29,"address":{"provice":"shanghai","city":"shanghaic","district":"pudong"}}// 访问对象中的属性console.log("man对象的name: ",man.name)console.log("man对象的adderss: ",man.address)console.log("man对象的adderss下的district: ",man.address.district)//定义JSON对象数组var arrjs = [{"id":"1111","name":"libai"},{"id":"2345","name":"baijuyi"},{"id":"6778","name":"menhaoran"}];//获取数组中的对象属性for(var i=0; i<arrjs.length; i++){var aj = arrjs[i];console.log(aj.id, aj.name);}//json转换//json转为字符串var libai1 = {"name":"libai","age":1000,"addr":"tang"};//查看libai1对象的类型,类型为Objectconsole.log(typeof libai1)//输出为对象console.log("json libai1: ",libai1);//将json对象转为字符串var str1 = JSON.stringify(libai1);//输出转换后的对象类型,类型为字符串类型console.log(typeof str1);//输出对象console.log("string str1: ",str1);console.log("----------------------------------------------------");//字符串转为JSON,注意,这里键值必须用双引号包裹,字符串最外层需用单引号,反之会报错var str2 = '{"name":"dufu","addr":"tang"}';//输出对象类型,类型为字符串stringconsole.log(typeof str2);//输出字符串内容console.log("string str2: ",str2);var jsonObj = JSON.parse(str2);//输出转换后的对象类型,类型为Objectconsole.log(typeof str2);//输出对象内容console.log("json jsonObj: ",jsonObj);var strjs = '[{"name":"li","addr":"song"},{"name":"zhao","addr":"ming"}]';console.log("string strjs: ",strjs);var jsonObjs = JSON.parse(strjs);console.log("json jsonObjs: ",jsonObjs);</script></head>
<body></body>
</html>

执行代码,浏览器控制台查看输出如下
在这里插入图片描述

4. 对象类型

4.1 对象介绍

    对象类型与Java中的引用数据类型相似JavaScript是面向对象的语言,但并不是纯粹的面向对象,不支持某些面向对象的特征

4.2 创建对象

创建对象有三种方式:使用Object创建、使用构造函数创建、使用json对象创建

4.2.1 使用Object创建对象
4.2.1.1 语法

创建对象语法

        //新创建的对象没有属性和方法var 对象名 = new Object();

添加属性名和值

        //为对象添加属性对象名.属性名 = 属性值;//为对象添加方法对象名.方法名 = function(){方法体};

调用属性和方法

        //调用属性对象名.属性名;//或者对象名["属性名"];//调用方法对象名.方法名();
4.2.1.2 示例

创建对象和调用的示例

        //新创建的对象没有属性和方法var o = new Object();//为对象添加属性名和属性值o.name = "libai";//为对象添加方法o.play = function(){console.log("方法体");};//属性和方法的调用var name = o.name;var name = o["name"];o.play();
4.2.2 使用构造函数创建对象
4.2.2.1 语法

使用构造函数创建对象的语法如下

        //为区别普通函数,构造函数名建议首字母大写function 构造函数名(形参1,形参2,...){this.属性名 = 形参1;this.属性名 = 形参2;this.方法名 = function(){方法体;};}
4.2.2.2 示例

使用构造函数创建对象的示例

        //举例,创建构造函数function User(name,age){//属性this.name = name;this.age = age;//方法this.study = function(){console.log("我是"+this.name+" 年龄:"+this.age);};this.doing = function(){console.log("正在敲代码");};}//使用构造函数创建对象var user = new User("libai","20");console.log(user.name, user.name);user.study();user.doing();
4.2.3 使用JSON对象结构创建对象

json本身就是一个对象,使用json结构也可以创建对象

4.2.3.1 语法

使用json对象创建对象的语法

        var JSON对象 = {//属性名可以不用引号属性名:属性值,属性名:属性值,...};
4.2.3.2 示例

使用json结构创建对象的示例

        var student = {"name":"zhangsan","age":"26","study":function(){console.log("在学习");}};console.log(student.name, student["age"]);student.study();

4.3 示例代码

创建对象相关的示例代码如下

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>复合类型-对象类型</title><script>/*对象类型与Java中的引用数据类型相似JavaScript是面向对象的语言,但并不是纯粹的面向对象,不支持某些面向对象的特征*///创建对象的三种方式//1使用Object//新创建的对象没有属性和方法var o = new Object();//为对象添加属性名和属性值o.name = "libai";//为对象添加方法o.play = function(){console.log("方法体");};//属性和方法的调用var name = o.name;var name = o["name"];o.play();//2使用构造函数,模拟类的定义,相当于定义一个类型//使用构造函数,模拟类的定义,相当于定义一个类型function Fun(a,b){this.name = a;this.age = b;this.play = function(){console.log();};}//举例,创建构造函数function User(name,age){//属性this.name = name;this.age = age;//方法this.study = function(){console.log("我是"+this.name+" 年龄:"+this.age);};this.doing = function(){console.log("正在敲代码");};}//使用构造函数创建对象var user = new User("libai","20");console.log(user.name, user.name);user.study();user.doing();//3使用JSON格式对象,一般只在JSON对象中定义属性var student = {"name":"zhangsan","age":"26","study":function(){console.log("在学习");}};console.log(student.name, student["age"]);student.study();</script></head>
<body></body>
</html>

浏览器控制台输出如下
在这里插入图片描述

5. 示例代码下载

本文示例代码已上传至CSDN资源库
下载地址:JavaScript 复合类型 示例代码


感谢阅读,祝君暴富!


关键字:JS(JavaScript)的复合类型详解

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: