JavaScript 变量 及 案例练习

变量

一. 变量是什么:

问题1: 用户输入的数据我们如何存储起来?

答案1: 使用变量

理解变量是如何存储数据的 “容器

  1. **变量: **

    • 白话: 变量就是一个装东西的盒子
    • 通俗: 变量是计算机中用来存储数据的 “容器” , 它可以让计算机变得有记忆
    • 注意: 变量不是数据本身, 它们仅仅是一个用于存储数值的容器, 可以理解为是一个个用来装东西的纸箱子

变量是盒子, 里面存储的东西是数据.

变量有什么作用呢?

用来存储数据的. 注意变量指的是容器而不是数据.

生活中的变量:
  • HTML标签
  • 教室
  • 宿舍
  • 杯子

二. 变量的基本使用

1. 声明变量
  1. 要想使用变量, 首先需要创建变量 (也称为声明变量或者定义变量)

    语法:

    let 变量名
    
    • 声明变量有两部分构成: 声明关键字, 变量名(标识)

    • let 即关键字(let: 允许, 许可, 让, 要), 所谓关键字是系统提供专门用来声明 (定义) 变量的词语

      当然有的小伙伴说var 也可以, 但是请大家把var忘掉, 它是我们的前任他不适合我们, 适合的话也不会变成前任了

    举例:

    // 1. 声明一个年龄的变量
    let age;
    
    • 我们声明了一个age变量
    • age即变量的名称, 也叫做标识符
2. 变量赋值

定义开了一个变量后, 你就能够初始化它(赋值). 在变量名后跟一个 “=” , 然后是数值.

在这里它 “=” 不叫等号, 叫做赋值号

// 1. 声明一个年龄的变量
let age;
age = 18  //把18给age

age: 变量

18: 字面量

注意: 是通过变量名来获得变量里的数据

// 1. 声明一个年龄的变量
let age;
age = 18  //把18给age
console.log(age)

此时现在控制台上就有了18这个数据

变量的初始化:

声明变量的同时直接赋值

let age = 18

这个变量不再是空的了, 叫做初始化变量为18

总结:

  1. 变量是使用什么关键字来声明?

    • let
  2. 变量通过什么符号来赋值?

    • = 这个符号我们也称为 赋值运算符
变量练习

需求:

  1. 声明一个变量, 用于存放用户购买的商品 ==数量(num) ==为 20
  2. 声明一个变量, 用于存放用户的 姓名(uname) 为 ‘张三’
  3. 依次控制台打印输出两个变量
// 用户购买的商品
let num = 20;
// 用户姓名
let uname = '张三'
//控制台打印
console.log(num)
console.log(uname)
3. 更新变量

变量赋值后, 还可以通过简单地给它一个不同的值来更新它

// 用户年龄
let age = 18;
// 更新变量
age = 19;

错误的写法

// 用户年龄
let age = 18;
// 更新变量
// 注意不能这样写
let age = 19; //控制台会报错

如果使用var来声明变量

// 如果使用var来声明变量
var agevar = 18;
// 更新变量
var agevar = 19;

//控制台打印
console.log(agevar)

此时控制台出现 19 并且一个false undefined, 所以说这里我们不使用var了, 它是我们的前任, 有一定的问题

注意: let不允许多次声明一个变量

4. 声明多个变量

语法: 多个变量中间用逗号隔开

let age = 18, uname = '张三'
console.log(age, uname)

并不提倡大家这么写

*提倡大家还是一行只声明变量一个变量, 为了更好的可读性 *

总结:

  1. 变量赋值后如何更新新值?

    • 直接给他一个不同的值来更新它, 注意不可加 let
  2. 我们提倡同时声明多个不同的变量吗?

    • 不提倡, 可读性不好
1. 变量案例-弹出姓名

需求: 浏览器中弹出对话框: 请输入姓名, 页面中输出: 刚才输入的姓名

// 1. 用户输入
// prompt('请输入姓名')
// 2. 内部处理保存数据
let uname = prompt('请输入姓名')
// 3. 打印输出
document.write(uname)
2. 变量案例-交换变量的值

需求:

有2个变量: num1 里面放的是 10 , num2 里面放的是 20

最后变为 num1 里面放的是 20 , num2 里面放的是 10

目的:

  1. 练习变量的使用
  2. 为了后面冒泡排序做准备

分析:

  1. 核心思路: 使用一个临时变量 用来做中间存储
// 临时变量
let temp;
let num1 = 10;
let num2 =20;
// num1 = temp //这么写是错误的
// 我们的变量是把右边的给左边
temp = num1
// 把num2的值给num1
num1 = num2
num2 = temp
document.write(num1,num2)

三. 变量的本质

**内存: **计算机中存储数据的地方, 相当于一个空间

变量的本质: 是程序在内存中申请的一块用来存放数据的小空间

四. 变量命名规则与规范

规则

  • 不能使用关键字

    比如:

    let let;
    let if;
    let for;
    
    • 关键字: 有特殊含义的字符, JavaScript内置的一些词汇, 例如: let, var, if, for等
  • 只能用下划线, 字母, 数字, $组成, 且数字不能开头

  • 字母严格区分大小写, 如 Age 和 age 是不同的变量

规范:

  • 起名要有意义
  • 遵守小驼峰命名法

    • 第一个单词首字母小写, 后面每个单词首字母大写.

      例: userName

变量练习-输出用户信息
  • 需求: 让用户输入自己的名字, 年龄, 性别, 在输出到网页
  • 分析:
  • 1. 弹出输入框 (prompt): 请输入您的姓名 (uname): 用变量名保存起来.
  • 2. 弹出输入框 (prompt): 请输入您的年龄 (age): 用变量存起来
  • 3. 弹出输入框 (prompt): 请输入您的性别 (gender): 用变量存起来
  • 页面分别输出(document.write)刚才的3个变量
let uname = prompt('请输入您的姓名')
let age = prompt ('请输入您的年龄')
let gender = prompt ('请输入您的性别')

document.write('<h1>您的姓名为: '+uname+'</h1>')
document.write('<h1>您的年龄为: '+age+'</h1>')
document.write('<h1>您的性别为: '+gender+'</h1>')

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

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

相关文章

python获取文件路径

文件&#xff1a;allpath_parameter.py # 获取当前目录路径 # current_dir os.getcwd() # 获取当前目录路径 realpath00 os.path.abspath(os.path.join(os.path.dirname(os.path.split(os.path.realpath(__file__))[0]), .)) print(realpath00)# 获取当前目录的上级目录路…

C++ 并发编程 - 入门

目录 写在前面 并发编程&#xff0c;启动&#xff01; 写在前面 计算机的并发指在单个系统里同时执行多个独立的任务。 在过去计算机内只有一个处理器时并发是通过快速的切换进程上下文所实现的&#xff0c;而现在计算机已经步入了多核并发时代&#xff0c;所以多个进程的并…

【LAMMPS学习】八、基础知识(4.5)TIP5P水模型

8. 基础知识 此部分描述了如何使用 LAMMPS 为用户和开发人员执行各种任务。术语表页面还列出了 MD 术语&#xff0c;以及相应 LAMMPS 手册页的链接。 LAMMPS 源代码分发的 examples 目录中包含的示例输入脚本以及示例脚本页面上突出显示的示例输入脚本还展示了如何设置和运行各…

Kubernetes:云原生时代的核心引擎

文章目录 一、Kubernetes简介&#xff1a;引领云原生潮流二、K8s的核心特性&#xff1a;自动化与智能化三、K8s的实践应用&#xff1a;打造高效云原生应用架构四、K8s的挑战与应对&#xff1a;安全与性能并重五、K8s的未来展望&#xff1a;无限可能与挑战并存《Kubernetes快速进…

WPF —— lCommand命令实例

首先在标签页面设置一个Button按钮 <Button Width"100" Height"40" Content"测试" ></Button> 1 创建一个类 继承于ICommand这个接口&#xff0c; 这个接口一般包含三部分&#xff1a; 俩个方法&#xff1a;一个判断指令是不是…

主打熟人双向社交,UXLINK 如何用群组打造超强社交生态

社交&#xff0c;作为最强 Web3 流量入口 Web2 世界里&#xff0c;社交产品总是最具想象力。全球使用 Facebook 系列产品的日活用户&#xff08;DAP&#xff09;均值近 30 亿人&#xff0c;占全球人口的 1/3。然而&#xff0c;加密货币用户仅约有 4.2 亿&#xff0c;占全球人口…

STM32单片机C语言模块化编程实战:LED控制详解与示例

一、开发环境 硬件&#xff1a;正点原子探索者 V3 STM32F407 开发板 单片机&#xff1a;STM32F407ZGT6 Keil版本&#xff1a;5.32 STM32CubeMX版本&#xff1a;6.9.2 STM32Cube MCU Packges版本&#xff1a;STM32F4 V1.27.1 之前介绍了很多关于点灯的方法&#xff0c;比如…

2024年六西格玛黑带养成攻略:你的全面质量管理之路

成为一名六西格玛黑带&#xff0c;不仅意味着你在质量管理领域达到了专业水平&#xff0c;更是你职业生涯中的一大亮点。那么&#xff0c;如何在2024年成为一名六西格玛黑带&#xff1f;下面&#xff0c;深圳天行健六西格玛培训公司将为大家提供详细的规划和建议。 首先&#x…

C++ 核心编程(1)

c面向对象编程 1.内存分区模型 程序运行前为代码区和全局区。程序运行后才有栈区和堆区。。 1.1 程序运行前 #include<iostream> #include <bits/stdc.h> using namespace std; /*全局区全局变量、静态变量、常量 */ //全局变量 int g_1 20; int g_2 30; //const…

以场景驱动CMDB数据治理经验分享

数据治理是 CMDB 项目实施中难度最大、成本最高的环节&#xff0c;是一个长期治理的过程&#xff0c;而行业很少提出 CMDB 数据治理的技术实现方案。CMDB 数据治理不仅需要解决配置管理工程性的技术问题&#xff0c;还要基于运维组织的特点&#xff0c;建立适应性的配置运营能力…

查看HDF5文件软件(HDFView)

HDFView&#xff1a;下载地址 note&#xff1a;我们需要下载 win10 、App软件&#xff08;win10在win11也能运行&#xff09;&#xff0c;因为App软件是轻量版&#xff0c;不需要安装就可以使用。 eg&#xff1a; 下载完后解压就可以使用。

空间数据索引的利器:R-Tree原理与实现深度解析

空间数据索引的利器&#xff1a;R-Tree原理与实现深度解析 R-Tree的原理插入操作分裂操作查询操作 R-Tree的伪代码R-Tree的C语言实现讨论结论 R-Tree是一种平衡树&#xff0c;用于空间数据索引&#xff0c;特别是在二维或更高维度的几何对象存储和检索中。它由Antony Guttman和…

书生·浦语 大模型(学习笔记-9)OpenCompass 大模型评测实战

目录 一、评测实现双赢 二、评测遇到的问题 三、如何评测大模型&#xff08;大概总结4大类方法&#xff09; 四、评测工具链及流水线 五、实战评测 GPU的环境安装 查看支持的数据集和模型 启动评测(会缺少protibuf库&#xff0c;提前安装&#xff09; 测评结果 一、评…

【蓝桥2025备赛】容斥原理

容斥原理 背景&#xff1a;两个集合相交 高中的韦恩图&#xff0c;我们知道两个集合相交时我们可以通过简单的计算来认识相关的性质 集合相交的区域是 A ∩ B A\cap B A∩B ,集合的并集是 A ∪ B A\cup B A∪B ,那怎么用集合表示 A ∪ B A\cup B A∪B 我们可以看作是A集合…

正点原子[第二期]Linux之ARM(MX6U)裸机篇学习笔记-6.3

前言&#xff1a; 本文是根据哔哩哔哩网站上“正点原子[第二期]Linux之ARM&#xff08;MX6U&#xff09;裸机篇”视频的学习笔记&#xff0c;在这里会记录下正点原子 I.MX6ULL 开发板的配套视频教程所作的实验和学习笔记内容。本文大量引用了正点原子教学视频和链接中的内容。…

mybatis的使用技巧9——mysql按年、季度、月、周等不同时间维度查询或分组统计

在实际项目开发过程中&#xff0c;按不同时间维度查询业务数据的操作异常频繁。比较多的操作如支持按时间周期范围做列表数据的筛选&#xff0c;或者是按年月日等维度的图表展示&#xff0c;亦或者是首页的概况&#xff0c;三维大屏的展示等&#xff0c;都离不开不同时间周期查…

网络靶场实战-Qiling Fuzz实例分析

背景 在上一小节中&#xff0c;介绍了qiling框架的背景和基础使用&#xff0c;并以相关的CTF和qilinglab实例进行练习加深对qiling框架的使用&#xff0c;后续并简单介绍了qiling fuzz的功能。 在这一小节&#xff0c;我们将对qiling fuzz iot设备进行测试以及以实例的方式对…

中级信息系统管理工程师-必会题锦集

文章目录 中级信息系统管理工程师-必会题锦集题目一CPU[解析]试题二 CPU[解析] 中级信息系统管理工程师-必会题锦集 题目一CPU CPU中&#xff08;1&#xff09;不仅要保证指令的正确执行&#xff0c;还要能够处理异常事件。 A. 运算器 B. 控制器 C. 寄存器组 D. 内部总线 [解…

1.C++入门(上)

目录 1.C关键字 2.命名空间 作用域方面的优化 a.命名空间定义 b.命名空间使用 3.C 输入&输出 1.C关键字 C有63个关键字&#xff0c;C语言有32个关键字&#xff0c;存在重叠如荧光笔标出 2.命名空间 作用域方面的优化 如果变量&#xff0c;函数和类的名称都存在于全…

SpringBootWeb请求

文章目录 前言一、Postman介绍 二、简单参数三、实体参数四、数组集合参数五、日期参数六、JSON参数七、路径参数 前言 在上一篇文章中&#xff0c;已经基于SpringBoot的方式开发一个web应用&#xff0c;浏览器发起请求 /hello 后 &#xff0c;给浏览器返回字符串 “Hello Wor…
最新文章