续-初识JAVaScript---(2)

news2024/11/19 17:19:26

初识JavaScript ———(2)!!!

一、关于JavaScript中的数据类型

虽然在JS中的变量在声明的时候不需要指定数据类型,但是在赋值的时候,每一个数据还是有类型的,所以还是需要学习JS中的数据类型。

JS的数据类型遵循ES规范(ECMAScipt规范),在ES6之后,又基于以下的六种类型之外添加了一种新的类型:Symbol

1.数据类型的分类

(1)原始类型

在JS中的原始的数据类型有:Undefined、Number、String、Boolean、Null

(2)引用类型

在JS中的引用的数据类型有:Object以及Object的子类

JS中有一个运算符叫做typeof,这个运算符可以在程序的运行阶段动态的获取变量的数据类型。以下是typeof运算符的语法格式:

typeof 变量名

typeof运算符的运算结果是以下6个字符串之一,注意字符串都是全部小写。

“undefined” “number” “string”

“boolean” “object” “function”

在JS中比较字符串是否相等使用“==”完成,不是使用equals。

Demo:要求a变量和b变量的数据类型必须是数字,不能是其他变量,也就是限制了变量的数据类型

<html>
    <head>
        <meta charset="UTF-8">
        <title>My_javascript</title>
    </head>
    <body>
        <script type = "text/javascript">
               function sum(a,b) {
                    if(typeof a == "number" && typeof b == "number") {
                        return a + b;
                    }
                    alert(a+","+b+"必须都为数字!");
               }
               //正确的方式:
               var ret = sum(2,3);
               alert("ret = "+ret);
               //错误的方式:
               var ret2 = sum(false,"abc");
               alert("ret = "+ret2);
           </script>
    </body>
</html>

正确的执行结果:

在这里插入图片描述

错误的执行结果:

在这里插入图片描述

在这里插入图片描述

由于代码执行到了alert(a+","+b+"必须都为数字!");这句,说明sum函数并没有返回值,即ret2也没有接受到返回值,默认为undefined。

Demo:关于typedef的六种类型

<html>
    <head>
        <meta charset="UTF-8">
        <title>My_javascript</title>
    </head>
    <body>
        <script type = "text/javascript">
               var i;
               alert(i+"的数据类型为"+typeof i);

               var num = 3;
                alert(num+"的数据类型为"+typeof num);

               var str = "abc";
                 alert(str+"的数据类型为"+typeof str);

               var flag = false;
                alert(false+"的数据类型为"+typeof false);

               var d = null;
                alert(d+"的数据类型为"+typeof d);
            
               

           </script>
    </body>
</html>

在这里插入图片描述

注:null属于Null类型,但是typeof运算符的结果类型是“object”.

2.Undefined类型

Undefined类型只有一个值,这个值救赎undefined,当一个变量没有手动赋值,系统默认赋值undefined,或者也可以给一个变量手动赋值undefined。

var i;     //类型为undefined
var k = undefined;    //类型为undefined
alert(i==k);   //true

var j = "undefined";   //类型为string
alert(j==k);   //false

3.Number类型

(1)NUmber类型有哪些值?

整数、小数、负数、正数、不是数字、无穷大都属于Number类型(0、1、1.2、-1、NaN、Infinity)

关于NaN:表示Not a Number,不是一个数字,但属于Number类型。比如当运算结果应该是一个数字,最后算完不是一个数字的时候,结果就是NaN。

如,Demo:

 var a = 100;
 var b = "abc";
 alert("结果="+a/b);

在这里插入图片描述

但是如果做的是加法运算,加号的一边为字符串时,先做字符串的拼接。Demo:

var a = 100;
var b = "abc";
alert("结果="+(a+b));

在这里插入图片描述

4.Infinity类型

关于Infinity类型是当除数为0时,结果为无穷大。

alert(10/0);

在这里插入图片描述

思考:alert(10/3)=?

在这里插入图片描述

5.isNaN函数

用法:isNaN(数据),这个结果为true表示不是一个数字,结果为false表示是一个数字。因为isNaN的意思为:is Not a Number。

再对于之前,效果可和ypeof关键字替换,Demo:

<html>
    <head>
        <meta charset="UTF-8">
        <title>My_javascript</title>
    </head>
    <body>
        <script type = "text/javascript">
            function sum(a,b){
                if(isNaN(a) || isNaN(b)){
                    alert("参与运算的必须是数字!!!");
                    return;
                }
                return a+b;
            }
            var ret = sum(3,2);
            alert("ret="+ret);
        </script>
    </body>
</html>

在这里插入图片描述

6.parseInt( )函数和parseFloat函数

parseInt( )函数作用:可以将字符串自动转换成数字,并且取整数位。

parseFloat( )函数作用:可以将字符串自动转换成数字

Demo:

alert(parseInt("3.9999"));//3
alert(parseInt(3.9999));//3
alert(parseFloat("3.2")+1);//4.2

7.Math.ceil函数

Math.ceil函数作用:将数字进行向上取整,Math是数学类,数学类中有一个ceil( ),作用是向上取整。

alert(Math.ceil(2.1));

结果就是3

8.Boolean类型

JS中的Boolean类型永远就只有两个值,true and false(和Java一样)。

在Boolean类型中有一个函数叫做:Boolean( ).

语法格式:

Boolean(数据)

其作用是将非布尔类型转换成布尔类型。

Demo1:

var username = "";
if(username) {
     alert("欢迎你"+username);
}else {
     alert("用户名不能为空!");
}

Demo2:

var username = "";
if(Boolean(username)) {
     alert("欢迎你"+username);
}else {
     alert("用户名不能为空!");
}

Demo1和Demo2的代码含义是一样的,如果username中包含字符串,经过if语句判断,如果为真,即结果就是true,就会执行第一条语句alert("欢迎你"+username);但是我们一般采用第一种写法,代码底层会自己变化。

alert(Boolean(1));//true
alert(Boolean(0));//false
alert(Boolean(""));//false
alert(Boolean("abc"));//true
alert(Boolean(null));//false
alert(Boolean(NaN));//false
alert(Boolean(undefined));//false
alert(Boolean(Infinity));//true

总结:Boolean函数中有内容就转换成true,没有内容就是false。

9.Null类型

Null数据类型就一个值,null

注:alert(typeof null);这个代码的结果是object

10.String数据类型

(1)在JS当中字符串可以使用单引号,也可以使用双引号。

var str1 = "abc";

var str2 = 'abc';

(2)在JS中使用两种方式创建字符串:

  • var str = "abc";
  • 使用JS中内置的支持类(String),var str2 = new String("abc");注意,String是一个内置类,可以直接使用,String的父类是Object。
//小string(属于原始类型String)
var x = "abc";
alert(typeof x); //结果为string

//大String(属于Object类型)
var y = new String("abc");
alert(typeof y); //结果为object
  • 但是不管小string 还是大String,他们的属性和函数都是通用的。

(3)关于String类型常用的属性和函数?

  • 常用属性:
    • length 获取字符串长度
  • 常用函数:
    • indexof 获取指定字符串在当前字符串第一次出现处的下标
    • lastIndexof 获取指定字符串在当前字符串最后一次出现处的下标
    • replace 替换
    • substring 截取子字符串
    • toLowerCase 转换成小写
    • toUpperCase 转换成大写
    • split 拆分字符串

11.Object数据类型

Object是所有类型的超类,自定义的任何类型,默认继承Object。

(1)JS常见的属性

常见的属性:prototype属性(这个属性主要是给类动态的扩展属性和函数)、constructor属性

(2)JS中常见的函数

在JS中有toString、valueOf、tolocaleString函数等等

注:Object当中定义的类默认继承Object,会继承Object类中的所有属性以及函数,也就是说,自己定义的类中也有prototype属性

(3)在JS中如何定义类?又如何new对象?

  • 定义类的第一种方式:
    • function 类名(形参){};
  • 定义类的第二种方式:
    • 类名 = function(形参){};
  • 创建对象的方式:
    • new 类名(构造方法名)(形参);

Demo:

function test() {
            
            }
test();//这样用就是一个函数
            
var obj = new test();//这样用,object就是一个引用,保存内存地址指向堆中的对象。

(4)在JS中类的定义和构造函数的定义是一起完成的。

Demo:

function User(a,b,c) {
//this表示当前对象,User类中有三个属性:name、age、number
	this.name = a;
    this.age = b;
 	this.number = c;
}

//创建对象:
var user1 = new User("zhangsan",18,123);
//访问对象的属性:
alert(user1.name);     //zhangsan
alert(user1.age);      //18
alert(user1.number);   //123

二、null、NaN、undefined这三值的区别

1.数据类型不一样

null数据类型为object、NaN数据类型为number、undefined的数据类型为undefined

alert(null==NaN);        //false
alert(null==undefined);  //true
alert(undefined==NaN);   //false

//所以:null和undefined可以等同

注:在JS中有两个比较运算符

  • (1)“==”为等同运算符,只判断值是否相等
    • 例:alert(1==true);这个的结果就是true
  • (2)“===”为全等运算符,既判断值是否全等,也判断数据类型是否相等
    • 例:alert(1===true);这个的结果就是false,因为这两个的数据类型不一样

好了,本期的博客就到此结束,下一期还会继续讲解JavaScript语言的续集,请大家持续关注,谢谢!!!

既然选择远方,当不负青春,砥砺前行。

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

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

相关文章

c语言第一课---------它来了,它来了,带着薪资走来了

作者前言: 这是我的gitee仓库:https://gitee.com/qin-laoda/python-exercises 有兴趣的小可爱们可以点进去看看,里面有我写的代码我们一起来借鉴 由于本人的自我介绍已经自我介绍过了,在我的的第一篇博客里,有兴趣的小可爱可以去看看, 作者的建议 下面我们简单介绍学好C语言…

【Python】Python进阶系列教程-- Python3 JSON 数据解析(九)

文章目录 前言Python 编码为 JSON 类型转换对应表&#xff1a;JSON 解码为 Python 类型转换对应表&#xff1a;json.dumps 与 json.loads 实例 前言 往期回顾&#xff1a; Python进阶系列教程-- Python3 正则表达式&#xff08;一&#xff09;Python进阶系列教程-- Python3 C…

LLVM 标准 C++ 排序算法

Nature 官网发表《深度强化学习发现更快的排序算法》。 排序或散列这样的基本算法在任何一天都会被使用数万亿次1。随着计算需求的增长&#xff0c;这些算法的性能变得越来越重要 算法已经集成到 LLVM 标准 C排序库中&#xff0c;使用强化学习的新算法替换掉了原有的 LLVM libc…

STM32CubeMX | 44 - 使用GPIO点亮单总线RGBLED

一、单总线RGBLED 1. 硬件连接 在DragonFly上有四个全彩灯相连: 其中RGB_LED连接到STM32的PB9引脚。 2. 单总线通信协议 单总线通信协议中,表示bit0和bit1的码型如下: 时序值如下: 驱动一个单总线RGBLED只需要传输24bit颜色数据即可(MSB,高位优先),格式如下(注意…

OpenGL 冯氏光照模型

1.简介 现实世界的光照是极其复杂的&#xff0c;而且会受到诸多因素的影响&#xff0c;这是我们有限的计算能力所无法模拟的&#xff0c;冯氏光照模型的主要结构由3个分量组成&#xff1a;环境(Ambient)、漫反射(Diffuse)和镜面(Specular)光照。下面这张图展示了这些光照分量看…

V4L2框架解析

和你一起终身学习&#xff0c;这里是程序员Android 经典好文推荐&#xff0c;通过阅读本文&#xff0c;您将收获以下知识点: 一、概览二、流程简介三、关键结构体四、模块初始化五、处理用户空间请求 一、概览 相机驱动层位于HAL Moudle与硬件层之间&#xff0c;借助linux内核驱…

MacOS使用docker安装nginx

文章目录 一、docker安装nginx1、查看可用的nginx2、安装Nginx镜像3、查看是否安装成功4、安装成功后执行nginx5、查看容器6、本地验证 二、创建本地挂载文件1、第一步&#xff1a;宿主机创建目录2、第二步&#xff1a;将docker安装的nginx里面文件复制到宿主机3、第三步&#…

安洵杯2023wp - ukfc战队

喜提牛马第23名&#xff0c;不过对于我来说尽力了。 主方向逆向、密码学都极限输出了、但是第二道同模的题差一个点没想通&#xff0c;没得写很难受。 补题&#xff1a;NULL Web CarelessPy 目录 Web CarelessPy Confronting robot Reverse ez_cpp babythread 3D_m…

深入学习 Mysql 引擎 InnoDB、MyISAM

tip&#xff1a;作为程序员一定学习编程之道&#xff0c;一定要对代码的编写有追求&#xff0c;不能实现就完事了。我们应该让自己写的代码更加优雅&#xff0c;即使这会费时费力。 &#x1f495;&#x1f495; 推荐&#xff1a;体系化学习Java&#xff08;Java面试专题&#…

【数据结构与算法】 01 链表 (单链表、双向链表、循环链表、块状链表、头结点、链表反转与排序、约瑟夫环问题)

一、线性表1.1 概念与特点1.2 线性表的存储结构1.3 常见操作1.4 应用场景 二、链表2.1 链表简介2.2 单向链表&#xff08;单链表&#xff09;2.21 基本概念2.22 单链表基本操作2.23 C语言实现▶ 带头结点▶ 不带头结点 2.3 双向链表2.31 基本概念2.32 与单链表比较2.33 双向链表…

【Python】Python进阶系列教程-- urllib(十三)

文章目录 前言urllib.requesturllib.errorurllib.parseurllib.robotparser 前言 往期回顾&#xff1a; Python进阶系列教程-- Python3 正则表达式&#xff08;一&#xff09;Python进阶系列教程-- Python3 CGI编程&#xff08;二&#xff09;Python进阶系列教程-- Python3 My…

C++面向对象丨3. 函数提高——默认参数、占位参数和函数重载

文章目录 系列文章目录基础入门面向对象 1 函数默认参数2 函数占位参数3 函数重载 系列文章目录 基础入门 C基础入门丨1. 初识C像极了C语言C基础入门丨2. 数据类型基础C基础入门丨3. 搞明白4类运算符——运算符C基础入门丨4. 程序结构有哪几种&#xff1f;——程序流程结构C基…

LVS负载均衡群集--NAT模式

目录 前言 一&#xff1a;企业群集应用概述 1、集群的含义 2、问题 3、 解决方法 二、企业群集分类 1、根据群集所针对的目标差异&#xff0c;可分为三种类型 2、负载均衡群集(Load Balance Cluster) 3、 高可用群集(High Availability Cluster) 4、 高性能运算群集(Hi…

华为OD机试真题 JavaScript 实现【素数伴侣】【2023 B卷 100分】,附详细解题思路

一、题目描述 若两个正整数的和为素数&#xff0c;则这两个正整数称之为“素数伴侣”&#xff0c;如2和5、6和13&#xff0c;它们能应用于通信加密。现在密码学会请你设计一个程序&#xff0c;从已有的 N &#xff08; N 为偶数&#xff09;个正整数中挑选出若干对组成“素数伴…

3 个令人惊艳的 AI 项目,开源了!

公众号关注 “GitHubDaily” 设为 “星标”&#xff0c;每天带你逛 GitHub&#xff01; 过去一周&#xff0c;从外界看&#xff0c;AI 貌似放缓了进步速度&#xff0c;但只有身处其中的人才能知道&#xff0c;AI 一直没有停下进化的脚步。 以下是 GitHub 过去一周&#xff0c;诞…

一杯奶茶,成为AIGC+CV视觉的前沿弄潮儿!

击上方“机器学习与AI生成创作”&#xff0c;关注星标 获取有趣、好玩的前沿干货&#xff01; 【AI生成创作与计算机视觉】知识星球 2022、2023年开始&#xff0c;基于扩散模型的AI绘画、ChatGPT系列大模型主导的AIGC狂潮已来&#xff01;大模型下的科研、工业应用方向&#xf…

YOLOV3——你总能在这找到你想要的答案

目录 一&#xff1a;前言&#xff1a; 二&#xff1a;更快&#xff0c;更强 网络结构图 其他基础操作&#xff1a; Darknet53的由来 三&#xff1a;最明显的特点&#xff1a; 四&#xff1a;多scale 五&#xff1a; 为什么vgg越深效果反而越差了&#xff1f; 六&#…

MySQL数据库(一)

前言 数据库分为关系型数据库和非关系型数据库&#xff0c;mysql属于关系型数据库。 SQL语法不区分大小写。 目录 前言 一、数据库的基础知识 &#xff08;一&#xff09;服务器和客户端的定义 &#xff08;二&#xff09;请求和响应 &#xff08;三&#xff09;MySQL的基…

uc-osⅡ入门——创建工程模板

目录 任务: 概念 简介 性质 组成 1) 核心部分(OSCore.c) 2) 任务处理部分(OSTask.c) 3) 时钟部分(OSTime.c) 4) 任务同步和通信部分 5) 与CPU的接口部分 总结分析和思考 任务管理 时间管理 内存管理 通信同步 任务调度 理解 实践 任务: 了解什么是ucos 创建…

Qt6构建于打包发布

打包发布 release 单文件打包 参考文献&#xff1a;https://blog.csdn.net/sasafa/article/details/126538432 首先准备我们欲打包发布的项目 默认情况下运行时发布的是 debug 类型的&#xff08;包含冗余调试信息&#xff0c;文件大&#xff09;&#xff0c;我们需要切换到 …