JS(JavaScript)的复合类型详解

news2025/1/14 18:41:47

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


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


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


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


文章目录

  • 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对象的类型,类型为Object
        console.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"}';
        //输出对象类型,类型为字符串string
        console.log(typeof str2);
        //输出字符串内容
        console.log("string str2: ",str2);
        var jsonObj = JSON.parse(str2);
        //输出转换后的对象类型,类型为Object
        console.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 复合类型 示例代码


感谢阅读,祝君暴富!


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

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

相关文章

vue3前后端开发:响应式对象不能直接成为前后端数据传输的对象

如图所示&#xff1a;前端控制台打印显示数据是没问题的&#xff0c;后端却显示没有接收到相应数据&#xff0c;但是后端的确接收到了一组空数据 直接说原因&#xff1a;这种情况唯一的原因是没有按正确格式传递参数。每个人写错的格式各有不同&#xff0c;我只是说明一下我在…

大模型应用研发基础环境配置(Miniconda、Python、Jupyter Lab、Ollama等)

老牛同学之前使用的MacBook Pro电脑配置有点旧&#xff08;2015 年生产&#xff09;&#xff0c;跑大模型感觉有点吃力&#xff0c;操作起来有点卡顿&#xff0c;因此不得已捡起了尘封了快两年的MateBook Pro电脑&#xff08;老牛同学其实不太喜欢用 Windows 电脑做研发工作&am…

第三方软件连接虚拟机

第三方软件连接虚拟机 1 查看本机VM&#xff08;VMware&#xff09;虚拟机网段2 开启虚拟机系统&#xff0c;修改网卡配置3 重新打开网络并测试连通性4 打开VM虚拟机网络开关5 通过第三方软件建立连接6 可能遇到的问题 1 查看本机VM&#xff08;VMware&#xff09;虚拟机网段 子…

vite+vue3+ts项目搭建流程 (pnpm, eslint, prettier, stylint, husky,commitlint )

vitevue3ts项目搭建 项目搭建项目目录结构 项目配置自动打开项目eslint①vue3环境代码校验插件②修改.eslintrc.cjs配置文件③.eslintignore忽略文件④运行脚本 prettier①安装依赖包②.prettierrc添加规则③.prettierignore忽略文件④运行脚本 stylint①.stylelintrc.cjs配置文…

EfficientNet-V2论文阅读笔记

目录 EfficientNetV2: Smaller Models and Faster Training摘要Introduction—简介Related work—相关工作EfficientNetV2 Architecture Design—高效EfficientNetV2架构设计Understanding Training Efficiency—了解训练效率Training-Aware NAS and Scaling—训练感知NAS和缩放…

Android开发系列(九)Jetpack Compose之ConstraintLayout

ConstraintLayout是一个用于构建复杂布局的组件。它通过将子视图限制在给定的约束条件下来定位和排列视图。 使用ConstraintLayout&#xff0c;您可以通过定义视图之间的约束关系来指定它们的位置。这些约束可以是水平和垂直的对齐、边距、宽度和高度等。这允许您创建灵活而响…

win10修改远程桌面端口,Windows 10下修改远程桌面端口及服务器关闭445端口的操作指南

Windows 10下修改远程桌面端口及服务器关闭445端口的操作指南 一、修改Windows 10远程桌面端口 在Windows 10系统中&#xff0c;远程桌面连接默认使用3389端口。为了安全起见&#xff0c;建议修改此端口以减少潜在的安全风险。以下是修改远程桌面端口的步骤&#xff1a; 1. 打…

AI 编程还有前景嘛?

自从各个大厂相继出品 AI 编程助手之后&#xff0c;AI 在编程领域的发展&#xff0c;可谓是几无寸进。 相比于 AI 在多模态领域火热&#xff0c;AI 在编程领域的热度已经完全下来了。 阿七在公众号搜索了关键词「AI编程」&#xff0c;发现搜索出来的公众号寥寥无几&#xff0…

[学习笔记] 禹神:一小时快速上手Electron笔记,附代码

课程地址 禹神&#xff1a;一小时快速上手Electron&#xff0c;前端Electron开发教程_哔哩哔哩_bilibili 笔记地址 https://github.com/sui5yue6/my-electron-app 进程通信 桌面软件 跨平台的桌面应用程序 chromium nodejs native api 流程模型 main主进程 .js文件 node…

【Unity小技巧】记一个RenderTexture无法正确输出Camera视图下的Depth渲染的问题

问题 这个问题出现在使用URP管线时&#xff0c;我试图用Shader实现血条的制作&#xff0c;并用RenderTexture将视图渲染到RawImage上。 但是渲染结果出现了问题&#xff1a; 可以看到液体边缘的渲染出现了错误&#xff0c;原因不明 在StackFlow上查找后找到了类似的问题&…

嵌入式学习(Day 51:ARM指令/汇编与c语言函数相互调用)

1.Supervisor模式与SVC模式 Supervisor模式是ARM处理器的一个特权工作模式&#xff0c;允许执行特权指令和访问特权资源。SVC模式&#xff08;Supervisor Call&#xff09;是与Supervisor模式相关的一个功能或指令&#xff0c;用于从用户模式切换到Supervisor模式&#xff0c;…

MySQL报错Duplicate entry ‘0‘ for key ‘PRIMARY‘

报错现场 现象解释 因为你在插入时没有给 Customer.Id 赋值&#xff0c;MySQL 会倾向于赋值为 NULL。但是主键不能为 NULL&#xff0c;所以 MySQL 帮了你一个忙&#xff0c;将值转换为 0。这样&#xff0c;在第二次插入时就会出现冲突&#xff08;如果已经有一条记录为 0&…

Linux系统中根下的目录结构介绍

一、Linux的路径分隔符 Linux系统中使用正斜杠(/)作为路径分隔符&#xff1b;每个目录的后面都默认带有一个正斜杠&#xff08;如&#xff1a;需要进入opt目录可以分别使用【cd /opt】或【cd /opt/】&#xff09; 二、Linux根目录下各个目录结构介绍 红色标识的文件夹为Linux的…

Vue3基础使用

目录 一、创建Vue3工程 (一)、cli (二)、vite 二、常用Composition API (一)、setup函数 (二)、ref函数 (三)、reactive函数 (四)、setup注意事项 (五)、计算属性 (六)、watch (七)、watchEffect函数 (八)、生命周期 1、以配置项的形式使用生命周期钩子 2、组合式…

LeetCode 算法:将有序数组转换为二叉搜索树 c++

原题链接&#x1f517;&#xff1a;将有序数组转换为二叉搜索树 难度&#xff1a;简单⭐️ 题目 给你一个整数数组 nums &#xff0c;其中元素已经按 升序 排列&#xff0c;请你将其转换为一棵 平衡 二叉搜索树。 示例 1&#xff1a; 输入&#xff1a;nums [-10,-3,0,5,9]…

怎么用电脑在线制作活码?快速将活码生成的操作方法

随着现在很多内容都可以通过生成二维码的方式来展示&#xff0c;所以在很多地方都会将内容生成二维码的方式让其他人通过扫码查看内容。二维码不仅能够简化用户获取内容的流程&#xff0c;还可以降低成本&#xff0c;有效提升用户体验&#xff0c;那么不同内容的二维码如何制作…

Golang笔记:使用serial包进行串口通讯

文章目录 目的使用入门总结 目的 串口是非常常用的一种电脑与设备交互的接口。这篇文章将介绍golang中相关功能的使用。 本文使用的包为 &#xff1a;go.bug.st/serial https://pkg.go.dev/go.bug.st/serial https://github.com/bugst/go-serial 另外还有一些常见的包如&…

构建家庭NAS之三:在TrueNAS SCALE上安装qBittorrent

本系列文章索引&#xff1a; 构建家庭NAS之一&#xff1a;用途和软硬件选型 构建家庭NAS之二&#xff1a;TrueNAS Scale规划、安装与配置 构建家庭NAS之三&#xff1a;在TrueNAS SCALE上安装qBittorrent 大部分家庭NAS用户应该都会装一个下载工具。本篇以qBittorrent为例&…

Linux-笔记 全志T113移植正点4.3寸RGB屏幕笔记

目录 前言 线序整理 软件 显示调试 触摸调试 背光调试 前言 由于手头有一块4.3寸的RGB屏幕(触摸IC为GT1151)&#xff0c;正好开发板上也有40Pin的RGB接口&#xff0c;就想着给移植一下&#xff0c;前期准备工作主要是整理好线序&#xff0c;然后用转接板与杜邦线连接验证好…