5.常量和数据类型(数字类型,字符串类型,模板字符串,布尔类型undefined,null检测数据类型),类型转化

什么是常量

常量就是不能改变的量,就是向计算机内存要一款空间然后存储的东西不能改变用const声明并且一定要初始化值

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        
    </body>

    <script>
        // 常量意思就是跟计算机内存要一个盒子,但是这个盒子里面的东西和变量不一样,变量盒子里面的东西可以来回变化
        //但是常量是不能改变盒子里的东西的,注意变量用let声明但是常量使用const声明,并且在声明的时候一定要赋值
        const PI = 3.141592653  // 注意常量一定要赋值并且一般都是全大写字母
        //注意常量PI不能修改,一旦在下面修改js就报错了
        console.log(PI)
    </script>
</html>

结果
在这里插入图片描述

数据类型

在js中数据类型主要分为两大类
基本数据类型和引用数据类型
B站的图片

  1. 数字类型:整数,正数,负数,小数,0
    下面的练习,弹窗输入圆的半径在画面上显示圆的周长和半径
    2.这里数字类型有一个特别的值是NaN(就是not a number的意思)就在计算错误的时候出现这个值,注意他是数字类型的哦!(比如你用字符串类型的数据和数字类型的数据进行相减操作就会出现Nan的错误)
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        
    </body>

    <script>
        // js是一门弱数据类型的语言 因为所有的都是用let来声明,就是只有你赋值了我才知道他是啥数据类型
        let r = prompt('请输入圆的半径')
        document.write('圆的周长是'+2*r*Math.PI+'圆的面积是'+r*r*Math.PI)

    </script>
</html>

结果
在这里插入图片描述

字符串类型

其实就一串字符,可以用英文的单引号’'英文的双引号""或者用反引号来包裹``住的值叫做字符串

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        
    </body>

    <script>
        let my_str = 'hello world'
        let my_str1 = "hello world"
        let my_str2 = `hello world`
        let my_str3 = '123456'  // 注意这里数字加了引号就是字符串类型
        let my_str4 = ''  // 空串
        let my_str5 = '\''  // 注意使用反斜杠来输出转义单引号
        let my_str6 = '拼接' + '字符串'  // 使用加号来拼接字符串
        let age = 25 //用于下面拼接的变量
        let my_str7 = `${age} 岁了`  // 模板字符串外面必须是反引号就tab键上面英文模式内个
        console.log(my_str)
        console.log(my_str1)
        console.log(my_str2)
        console.log(my_str3)
        console.log(my_str4)
        console.log(my_str5)
        console.log(my_str6)
        console.log(my_str7)
        

    </script>
</html>

结果
在这里插入图片描述

布尔类型,undefined和null

布尔类型在js里面就两个true和false代表是和不是的意思
undefined就是在声明变量的时候,管计算机要了一款内存然后并没有告诉计算机里面装的是啥东西,就让计算机输出了,计算机也蒙了,就告诉你undefined意思是我是未定义的值,一般都是函数的时候少传了一个参数,会出现这个问题
null表示是赋值了但是啥也没有内容为空,注意null是有值的但是是空的,他是一个尚未创建的对象

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        
    </body>

    <script>
        // 布尔类型
        let my_bool = true  // 注意js里布尔类型只有true和false他俩是布尔类型的字面量
        console.log(my_bool)
        // undefined 未定义类型
        //啥时候会出现undefined呢?就是光声明了变量没告诉计算机这个变量里面存储的是啥东西就是undefined
        let my_undefined
        console.log(my_undefined)
        console.log(my_undefined + 1 )  // 这里是Nan就是你让一个变量里面啥都没有的加一结果就不是数字是错误的
        // null 为空类型 就是里面有值的是一个还没有呗创建的对象,这里先用null代替的意思
        console.log(null + 1 )   // 这个是1 就说明null是有值的 其实这里是不太合理的,但是因为js的作者是用十天开发出来的所以会有很多bug
        // 检测数据类型
        console.log(typeof my_bool)
    </script>
</html>

执行结果
在这里插入图片描述

类型转化

基本上开发过程中一定会遇见类型的转化,后端传值肯定会出现和前端不一致的情况,还有就是表单里面提交的数据默认全都是字符串类型的哦

  1. 隐式转换
    直接引用B站的图把自己懒得写了没啥东西
    直接引用B站的图把自己懒得写了没啥东西
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        
    </body>

    <script>
        // 在表单里面串回来的数据全都是字符串类型的
        let my_data = prompt('请输入一个数字')
        console.log(typeof my_data)  // 这里输出是string
        // 隐式转换  某些运算符在执行的时候会自动的转化数据类型  比如加号 加号两边如果有一个是字符串类型的那么加号的另一边
        //就算是数字类型也会被转化成字符串类型
        console.log(my_data + 1)
        console.log(typeof(my_data + 1))
        // 显示转换  就是通过调用一些函数来转化数据的类型
        let my_srt = '123'
        console.log(typeof(Number(my_srt)))  // 转化为了数字类型 注意只能中转化数字奥你弄一个汉字他报错!
        console.log(parseInt('12.3***'))  // 这里输出12parseInt会把后面的.3***给去掉
        console.log(parseFloat('12.3***'))  // 输出12.3把后面的***去掉了


    </script>
</html>

运行结果
在这里插入图片描述

小案例,输入员工相关信息再表格里面输出对应的工资

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <style>
        h1{
            text-align: center;
        }
        table{
            /* 合并边框 */
            border-collapse: collapse;
            height: 80px;
            margin: 0 auto;
        }
        th{
            padding: 10px 30px;
        }
        table,th,td{
            border: 1px solid black;
            text-align: center;
        }
    </style>
    <body>
        <h1>员工工资</h1>
        <!-- <table>
            <tr>
                <th>员工姓名</th>
                <th>这个月工资</th>
                <th>扣税</th>
                <th>实际工资</th>
            </tr>
            <tr>
                <td>张三</td>
                <td>1000</td>
                <td>100</td>
                <td>900</td>
            </tr>
            
        </table> -->
    </body>

    <script>
        // 用户输入
        let name = prompt("请输入员工姓名");
        let salary = Number(prompt("请输入工资"));
        let tax = salary * 0.1;  // 税率0.1
        let realSalary = salary - tax;  // 实际工资
        document.write(`
        <table>
            <tr>
                <th>员工姓名</th>
                <th>这个月工资</th>
                <th>扣税</th>
                <th>实际工资</th>
            </tr>
            <tr>
                <td>${name}</td>
                <td>${salary}元</td>
                <td>${tax}元</td>
                <td>${realSalary}元</td>
            </tr>
            
        </table>
        `);
    </script>
</html>

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

SAP-PS-001-006问题预算占用与订单实际金额不一致

前言 PS模块最复杂的业务场景主要就是ETO&#xff08;Engineering-To-Order&#xff09;&#xff0c;也就是边设计边生产边采购的三边业务。 意味着从前端设计开始的成本就已经要进行收集&#xff0c;其次对于大型非标设备的生产发货只是一个环节&#xff0c;发货后还会涉及到现…

STL之stack+queue的使用及其实现

STL之stackqueue的使用及其实现 1. stack&#xff0c;queue的介绍与使用1.1stack的介绍1.2stack的使用1.3queue的介绍1.4queue的使用 2.stack&#xff0c;queue的模拟实现2.1stack的模拟是实现2.2queue的模拟实现 3.总结 所属专栏&#xff1a;C“嘎嘎" 系统学习❤️ &…

API网关架构设计与实现的经验总结与实践

API网关是现代微服务架构中的重要组件&#xff0c;它充当了前端和后端微服务之间的中介。本文将介绍API网关的架构设计原则和实现方法&#xff0c;以帮助开发人员更好地理解和应用这些技术。 1. 什么是API网关&#xff1f; - 解释了API网关的基本概念和作用&#xff0c;以及…

【c++入门】母牛生小牛

说明 有一头小母牛&#xff0c;从出生第四年起每年生一头小母牛&#xff0c;按此规律&#xff0c;第N年时有几头母牛&#xff1f; 输入数据 只有一个整数N&#xff0c;独占一行。(1≤N≤50) 输出数据 对每组数据&#xff0c;输出一个整数&#xff08;独占一行&#xff09;…

SAP-PS-02-003跨系统/Client请求传输和请求副本的创建

前言 某公司SAP服务器架构如下&#xff08;举例&#xff09;&#xff0c;一般进行SAP项目实施基本会遵循以下的系统和Client准则&#xff0c;那在不同系统和Client要如何进行请求传输呢 服务器 Client 作用 要求 DEV 100 业务顾问进行系统配置 所有配置均在该Client进行…

如何用Hexo搭建一个优雅的博客

引言 在数字化时代&#xff0c;拥有一个个人博客已经成为许多人展示自己技能、分享知识和与世界互动的重要方式。而在众多博客平台中&#xff0c;Hexo因其简洁、高效和易于定制的特点而备受青睐。本文将详细介绍如何从零开始搭建一个Hexo博客&#xff0c;让你的个人博客在互联…

synchronized关键字的底层原理

一、synchronized的使用方式 在语法上&#xff0c;要使用synchronized关键字&#xff0c;需要把任意一个非null对象作为"锁"对象&#xff0c;也就是需要一个对象监视器&#xff08;Object Monitor&#xff09;。总的来说有三种用法&#xff1a; 1.1 作用在实例方法…

【C++第二阶段】运算符重载-【+】【cout】【++|--】

你好你好&#xff01; 以下内容仅为当前认识&#xff0c;可能有不足之处&#xff0c;欢迎讨论&#xff01; 文章目录 运算符重载加法运算符重载重载左移运算符递增|减运算符重载 运算符重载 加法运算符重载 What 普通的加减乘除&#xff0c;只能应付C中已给定的数据类型的运…

如何像工程师一样阅读 - 快速阅读技术书籍的9个技巧

0. 目的 在看了 Read Like an Engineer: 9 Tips for Reading Technical Books Fast 之后&#xff0c; 记录一些个人的看法&#xff0c;并在这篇英文文章上作为实验&#xff0c; 记录一下正确的阅读方法。 1. 第一次阅读 1.1 生词表 parcel of the job: 工作中必不可少的部分…

OpenCV-33 开运算和闭运算

目录 一、开运算 二、闭运算 三、形态学梯度 开运算和闭运算都是腐蚀和膨胀的基本应用。 一、开运算 开运算 腐蚀膨胀(腐蚀之后再膨胀) 开运算提供了另一种去除噪声的思路。&#xff08;腐蚀先进行去噪&#xff0c;膨胀再还原图像&#xff09; 通过API --- morphologyE…

面试经典150题——两数之和 II - 输入有序数组

"The only limit to our realization of tomorrow will be our doubts of today." - Franklin D. Roosevelt 1. 题目描述 2. 题目分析与解析 2.1 思路一——暴力求解 暴力求解的思路就是通过两次for循环&#xff0c;外层循环遍历整个数组&#xff0c;内层循环遍…

CSP-202109-1-数组推导

CSP-202109-1-数组推导 解题思路 如果 currentValue 与 previousValue 相同&#xff0c;说明这个值不是一个独特的新值&#xff0c;因此只将它加到 sumTotal 上。如果 currentValue 与 previousValue 不相同&#xff0c;说明这是一个新的独特值&#xff0c;因此既将它加到 su…

精简还是全能?如何在 Full 和 Lite 之间做出最佳选择!关于Configuration注解的Full模式与Lite模式(SpringBoot2)

&#x1f3c3;‍♂️ 微信公众号: 朕在debugger© 版权: 本文由【朕在debugger】原创、需要转载请联系博主&#x1f4d5; 如果文章对您有所帮助&#xff0c;欢迎关注、点赞、转发和订阅专栏&#xff01; 前言 关于 Configuration 注解&#xff0c;相信在座的各位 Javaer 都…

【开源】JAVA+Vue.js实现在线课程教学系统

目录 一、摘要1.1 系统介绍1.2 项目录屏 二、研究内容2.1 课程类型管理模块2.2 课程管理模块2.3 课时管理模块2.4 课程交互模块2.5 系统基础模块 三、系统设计3.1 用例设计3.2 数据库设计 四、系统展示4.1 管理后台4.2 用户网页 五、样例代码5.1 新增课程类型5.2 网站登录5.3 课…

计算机速成课Crash Course - 30. 万维网

今天继续计算机速成课Crash Course的系列讲解。 更多技术文章&#xff0c;全网首发公众号 “摸鱼IT” 锁定 -上午11点 - &#xff0c;感谢大家关注、转发、点赞&#xff01; 计算机速成课Crash Course - 30. 万维网 (qq.com) 30. 万维网 前两集我们深入讨论了电线、信号、交…

【DC渗透系列】DC-4靶场

主机发现 arp-scan -l┌──(root㉿kali)-[~] └─# arp-scan -l Interface: eth0, type: EN10MB, MAC: 00:0c:29:6b:ed:27, IPv4: 192.168.100.251 Starting arp-scan 1.10.0 with 256 hosts (https://github.com/royhills/arp-scan) 192.168.100.1 00:50:56:c0:00:08 …

Gateway API 实践之(八)FSM Gateway SSL 代理终端与 TLS 上游

FSM Gateway 流量管理策略系列&#xff1a; 故障注入黑白名单访问控制限速重试会话保持健康检查负载均衡算法TLS 上游双向 TLS 网关使用 HTTP 对外与客户端通信&#xff0c;而与上游服务使用 HTTPS 的功能&#xff0c;是一种常见的网络架构模式。在这种模式下&#xff0c;网关…

跟着cherno手搓游戏引擎【23】项目维护、2D引擎之前的一些准备

项目维护&#xff1a; 修改文件结构&#xff1a; 头文件自己改改就好了 创建2DRendererLayer&#xff1a; Sandbox2D.h: #pragma once #include "YOTO.h" class Sandbox2D :public YOTO::Layer {public:Sandbox2D();virtual ~Sandbox2D() default;virtual void O…

阿里云服务器租用价格表_2024一年_1个月_1小时收费价格表

2024年阿里云服务器租用价格表更新&#xff0c;云服务器ECS经济型e实例2核2G、3M固定带宽99元一年、ECS u1实例2核4G、5M固定带宽、80G ESSD Entry盘优惠价格199元一年&#xff0c;轻量应用服务器2核2G3M带宽轻量服务器一年61元、2核4G4M带宽轻量服务器一年165元12个月、2核4G服…

LabVIEW工业监控系统

LabVIEW工业监控系统 介绍了一个基于LabVIEW软件开发的工业监控系统。系统通过虚拟测控技术和先进的数据处理能力&#xff0c;实现对工业过程的高效监控&#xff0c;提升系统的自动化和智能化水平&#xff0c;从而满足现代工业对高效率、高稳定性和低成本的需求。 随着工业自…