边学边总结的前端笔记(JavaScript基础篇)_var num=1; var result=num-- + --num + ++num +num++-程序员宅基地

技术标签: web前端  JavaScript  

图片「学习笔记」JavaScript基础

前言

最近一直研究JavaScript内容,遂把这一阶段的学习内容整理成笔记,巩固所学知识,同时也会参考一些博客,书籍上的内容,查漏补缺,给自己充充电

文章内容如有错误,欢迎指正批评️️

工欲善其事,必先利其器,为了提高开发效率,选用VScode。

  • 管理-设置-常用设置-字体 Consolas, '微软雅黑 Light', monospace

  • Chinese 汉化Vscode

  • Prettier 格式化代码(缩进2格)

  • Auto Rename Tag 同步修改标签

  • HTML CSS SupportHtml文档的CSS支持

  • HTML Snippets 自动输入Html标签

  • JavaScript (ES6) code snippetsES6语法支持

  • open in browser 浏览器打开

编程基础

编程基础

「计算机语言」分为机器语言,汇编语言,高级语言。计算机内部最终执行的都是机器语言,由01这样的二进制数构成。

「数据存储单位」8bit(比特) = 1B(Byte)字节   千字节1KB = 1024B

「翻译器」高级语言编写的程序不能被计算机识别,需要经过转换,将源代码程序翻译成机器语言才能运行。浏览器里面的js解释器就是这样的一个翻译器。

「程序运行」

  • 打开某个程序时,先从硬盘中把程序的代码加载到内存中

  • CPU执行内存中的代码

  • 注意:之所以要内存的一个重要原因,是因为 cpu运行太快了,如果只从硬盘中读数据,会浪费cpu性能,所以,才使用存取速度更快的内存来保存运行时的数据。(内存是电,硬盘是机械)

初识JavaScript

「创始人」布兰登·艾奇(Brendan Eich),起初命名为LiveScript后来与Sun公司合作改名为JavaScript

「JavaScript」运行在客户端的脚本语言,不需要编译,由js解释器(js引擎)逐行解释执行。Node.js也可以用于服务器端编程。

「JavaScript组成」ECMAScript(JavaScript语法)、DOM(文档对象模型)、BOM(浏览器对象模型)

JavaScript的作用

  • 表单动态校验(密码强度检测)

  • 网页特效

  • 服务端开发(Node.js)

  • 桌面程序(Electron)、App(Cordova)、控制硬件-物联网(Ruff)、游戏开发(cocos2d-js)

「JavaScript书写位置」

JS有3种书写位置,分别为行内、内嵌和外部。

  1. 行内式

<input type="button" value="点我试试" 
onclick="alert('Hello World')" />
  1. 内嵌式

<script>
    alert('Hello  World~!');
</script>
  1. 外部式

引用外部js文件
<script src = "my.js"></script>

「注释」

  1. 单行注释

// 我是单行注释 (快捷键 ctrl + / )
  1. 多行注释

/*
  获取用户年龄和姓名
  并通过提示框显示出来
  点击vscode左下角管理-键盘快捷方式-切换块注释
  (默认快捷键 alt + shift + a) 修改为 (ctrl + shift + /)
*/

博主自己建的微信公众号:web前端技术圈 (回复2020,可以下载一些编程开发工具和项目实战)

如果还在IT编程的世界里迷茫,不知道自己的未来规划,学习没有动力,东也学一下,西也学习一下,那你可以加入web前端学习交流Q群:733581373, 里面有大神一起交流并走出迷茫。新手可进群免费领取学习资料,分享一些学习的方法和需要注意的小细节,每晚八点也会准时的讲一些前端的小案例项目。

变量

变量的概念

「变量」是程序在内存中申请的一块用于存放数据的空间。变量是用于存放数据的容器,可以通过变量名获取数据,甚至修改数据。

图片

变量的使用

「1. 声明变量」

// 1.声明变量
var num; // 声明一个 名称为 num 的变量

var是一个JS关键字,用来声明变量(variable变量的意思)。num是我们定义的变量名,可以通过变量名来访问内存中分配的空间。

「2. 赋值」

num = 10;//给 num 这个变量赋值为 10

「3. 变量的初始化」

声明一个变量并赋值, 我们称之为变量的初始化。

var num = 10;//声明变量并赋值为10 

「4. 变量语法扩展」

// 1.一个变量被重新赋值后,它原有的值会被覆盖掉,变量值以最后一次赋的值为准。
var num = 10;
num = 11;
// 2.同时声明多个变量(只需要写一个var,多个变量名之间用英文逗号隔开)
var num = 10, age = 15, name = 'fan';

声明变量特殊情况

情况 说明 结果
var  age ; console.log (age); 只声明 不赋值 undefined
console.log(age) 不声明 不赋值  直接使用 报错
age   = 10; console.log (age); 不声明   只赋值 10

「5. 变量命名规范」图片

数据类型

分为两类:简单数据类型(Number,String,Boolean,Undefined,Null)和复杂数据类型(object)。

简单数据类型 说明 默认值
Number 数字型,包含整型值和浮点型值 0
String 字符串型 ""
Boolean 布尔值型 false
Undefined var a;声明了变量a但是没有赋值,此时a = undefined undefined
Null var a = null;声明了变量a为空值 null

Number数字型

「数字型进制」

// 1.在JS中八进制前面加0,十六进制前面加 0x
var num1 = 07;   // 对应十进制的7
// 2.十六进制数字序列范围:0~9以及A~F
 var num = 0xA;   

「数字型范围」JavaScript中的数值有最大值和最小值

  • 最大值:Number.MAX_VALUE,值为:1.7976931348623157e+308

  • 最小值:Number.MIN_VALUE,值为:5e-32

  • 特殊值:Infinity 无穷大 -Infinity 无穷小 NaN 代表一个非数字

  • isNaN():用来判断一个变量是否为非数字的类型。非数字型为true,数字型为false。

String字符串型

// 1.字符串型可以是引号中的任意文本,语法为 单引号 和 双引号
var msg = '我的名字叫';
var name = "fan";

「1. 字符串转义符」都是以 \ 开头,详细如下

转义符 说明
\n 换行符,n是 newline 的意思
\\ 斜杆 \
\' 单引号 ‘
\" 双引号 "
\t tab 缩进
\b 空格,b是 blank 的意思

「2. 字符串长度」
    字符串是由若干字符组成的,这些字符的数量就是字符串的长度。

// 1.字符串型可以是引号中的任意文本,语法为 单引号 和 双引号
var msg = '我是帅气的饭老板';
console.log(msg.length); // 显示 8

「3. 字符串拼接」
    多个字符串之间可以使用 + 进行拼接,其拼接方式为 字符串 + 任何类型 = 拼接之后的新字符串。
    拼接前会把与字符串相加的任何类型转成字符串,再拼接成一个新的字符串

//1.1 字符串 "相加"
alert('hello' + ' ' + 'world'); // hello world
//1.2 数值字符串 "相加"
alert('100' + '100'); // 100100
//1.3 数值字符串 + 数值
alert('11' + 12);     // 1112 +号口诀:数值相加,字符相连
// 1.4 字符串拼接加强
var age = 18;
alert("饭老板今年" + age +"岁了");

布尔型Boolean

    布尔类型有两个值:true 和 false ,其中 true 表示真(对),而 false 表示假(错)。
    布尔型和数字型相加的时候, true 的值为 1 ,false 的值为 0。

console.log(true + 1) // 2
console.log(false + 1) // 1

Undefined 和 Null

    一个变量声明后没有赋值会有一个默认值undefined(如果相连或者相加时,注意结果)

  var variable;
  console.log(variable); // undefined
  console.log("你好" + variable); // 你好undefined
  console.log(11 + variable); // NaN
  console.log(true + variable);// NaN

    一个变量声明并赋值null,里面存的值为空

  var var2 = null;
  console.log(var2); // null
  console.log("你好" + var2); // 你好null
  console.log(11 + var2); // 11
  console.log(true + var2);// 1

获取变量类型及转换

  • 检测变量的数据类型 typeof

  var num = 10;
  console.log(typeof num)//结果为 number
  • 字面量:是源代码中一个固定值的表示法,就是字面量如何去表达这个值。通过数据的格式特征可以判断数据的类型

    • 有数字字面量:8,9,10

    • 字符串字面量:'饭老板',"前端开发"

    • 布尔字面量:true,false

「数据类型转换」

  • 转换为字符串

方式 说明 案例
toString() 转成字符串 var num=1; alert(num.toString())
String() 强制转换 var num=1; alert(String(num))
加号拼接字符串 和字符串拼接的结果都是字符串 var num=1; alert(num+'我是字符串')

 

  • 转换为数字型

方式 说明 案例
parseInt(String)函数 将string类型转成整数型 parseInt('11')
parseFloat(String)函数 将string类型转成浮点型 parseFloat('11.2')
Number() 强制转换函数 将string类型强制转换为数值型 Number('12')
js隐式转换 ( - * /) 利用算数运算隐式转换为数值型 '12' - 0

 

  • 转换为布尔型
    代表空、否定的值会被转换为false,如''、0、NaN、null、undefined 其余值都会被转换为true

方式 说明 案例
Boolean() 其他类型转换为布尔值 Boolean('true')

关键字和保留字

「标识符」指开发人员为变量、属性、函数、参数取得名字。标识符不能是关键字或保留字。

「关键字」指 JS本身已经使用了的字,不能再用它们充当变量名、方法名

包括:break、case、catch、continue、default、delete、do、else、finally、for、function、if、in、instanceof、new、return、switch、this、throw、try、typeof、var、void、while、with 等。

「保留字」实际上就是预留的“关键字”,意思是现在虽然还不是关键字,但是未来可能会成为关键字,同样不能使用它们当变量名或方法名。

boolean、byte、char、class、const、debugger、double、enum、export、extends、fimal、float、goto、implements、import、int、interface、long、mative、package、private、protected、public、short、static、super、synchronized、throws、transient、volatile 等。

注意:如果将保留字用作变量名或函数名,那么除非将来的浏览器实现了该保留字,否则很可能收不到任何错误消息。当浏览器将其实现后,该单词将被看做关键字,如此将出现关键字错误。


运算符与流程控制

运算符(操作符)

「运算符」是用于实现赋值、比较和执行算数运算等功能的符号。常用运算符分类如下

  • 算数运算符

  • 递增和递减运算符

  • 比较运算符

  • 逻辑运算符

  • 赋值运算符

「算数运算符」

运算符 描述 案例
+ 10+20=30
- 10-20=-10
* 10*20=200
/ 10/20=0.5
% 取余
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/webxh6/article/details/117172203

智能推荐

抖音引流跳转到微信加好友?免费教你创建一个链接!_抖音跳转加微信程序源码-程序员宅基地

文章浏览阅读770次,点赞9次,收藏8次。为了降低大家的门槛,可以使用开源的【引流宝】快速创建一个链接,这个链接生成的二维码,用抖音扫码,然后分享出去就是一张卡片,点击卡片就跳转到微信。在抖音想要跳转到微信,现在常规的做法就是通过微信小程序的Url Scheme跳转到微信并打开小程序指定的页面,这个已经有非常成熟的方案。你可以下载这个开源软件的代码,自行搭建引流宝系统,然后创建抖音跳转到微信的卡片即可。_抖音跳转加微信程序源码

spring基本bean注入方法配置_"<ref bean=\"c1\"/>"-程序员宅基地

文章浏览阅读316次。spring基本bean注入方法配置_""

Lua 入门_lua_setupvalue-程序员宅基地

文章浏览阅读1.4k次。此篇文章所有操作都是基于上一篇安装的docker容器内进行操作案例来自于菜鸟教程首先进入容器安装vimapk add vimLua 变量变量就是给一块内存区域赋予一个值。使得程序可以读取和修改相应内存中内容。变量由字母、数字、下划线组成。必须以字母或下划线开头。Lua 是大小写敏感的。变量分为全局变量和局部变量type variable_listlocal a, b = 1, 10 --局部变量c, d = 2, 20 -- 全局变量如果变量只定义了没有初始化_lua_setupvalue

3.3 ORACLE 的 EMP&DEPT表 建表语句_oracle emp建表语句-程序员宅基地

文章浏览阅读1.5k次,点赞2次,收藏15次。ORACLE 的 EMP&DEPT表 建表语句-- 创建表与数据CREATE TABLE EMP(EMPNO NUMBER(4) NOT NULL,ENAME VARCHAR2(10),JOB VARCHAR2(9),MGR NUMBER(4),HIREDATE DATE,SAL NUMBER(7, 2),COMM NUMBER(7, 2),DEPTNO NUMBER(..._oracle emp建表语句

使django支持PUT,DELETE的方案_django如何简单快速实现put、delete方法-程序员宅基地

文章浏览阅读9.5k次。第一种方案修改ajax中type方式并设置header,同时对put重新构建数据字典在对views中的方法进行类对象封装时,发现django并不支持像post和get一样将数据封装。 由于网页端无法设置method方法,在用postman和ajax开启pycharm对接口进行debug测试时发现:提交数据后并没有进入代码逻辑。 查阅资料得知,django支持put和delete方法..._django如何简单快速实现put、delete方法

vscode通过跳板机(堡垒机)连接remote服务器_vscode 连接堡垒机-程序员宅基地

文章浏览阅读2.9w次,点赞17次,收藏45次。先吐槽: 搞了一上午!!! 我太难了!!! 最近服务器不够用, 就差动手算深度学习梯度了!!! 向本科朋友借了几台机子跑, 这要是没上过大学, 研究生还不能毕业了呢!!!目录1. 简单任务介绍2. 本机的配置3. 跳板机的配置4.内网服务器的配置5. 怎么样不需要密码访问嘤嘤嘤~~1. 简单的任务介绍:我现在用的电脑叫做A, 然后借了一台服务器叫做C..._vscode 连接堡垒机

随便推点

【视频异常检测】用于无监督视频异常检测的合成伪异常:一种简单有效的基于掩码自动编码器的框架 论文阅读_synthetic pseudo anomalies for unsupervised video -程序员宅基地

文章浏览阅读1.4k次,点赞17次,收藏25次。由于用于训练的异常样本的可用性有限,视频异常检测通常被视为一类分类问题。许多流行的方法研究自动编码器(AE)在假设AE重建正常数据良好而重建异常较差的情况下产生的重建差异。然而,即使只有正常的数据训练,AE通常也能很好地重建异常,这会耗尽其异常检测性能。为了缓解这个问题,我们提出了一个简单而有效的视频异常检测框架。引入了伪异常样本,该样本通过嵌入随机掩码而仅从正常数据合成,而无需额外的数据处理。我们还提出了一种正态一致性训练策略,鼓励AE更好地从正态和相应的伪异常数据中学习规则知识。_synthetic pseudo anomalies for unsupervised video anomaly detect

加载sklearn加州房价数据集出错 housing = fetch_california_housing() HTTPError: HTTP Error 403: Forbidden解决方案_fetch_california_housing 403-程序员宅基地

文章浏览阅读7.9w次,点赞13次,收藏15次。本文主要介绍了加载sklearn加利福尼亚州房价数据集出错 HTTPError: HTTP Error 403: Forbidden的解决方案,希望能对新手有所帮助。文章目录1. 问题描述2. 解决方案_fetch_california_housing 403

html如何让文字变斜体,CSS中如何让文字变成斜体-程序员宅基地

文章浏览阅读4.4k次。我们在日常中经常会让文字倾斜,但是有很多小伙伴们不知道CSS中如何让文字变成斜体,那么我们现在就去看看CSS中让文字变成斜体的方法,希望对你有所帮助。Font-style:在CSS中用Font-style属性实现把文字设为斜体的。Font-style属性值:normal:正常的字体italic:斜体。对于没有斜体变量的特殊字体,将应用obliqueoblique:倾斜的字体Italic和obliq..._html斜体字

在Android studio中引入butterKnife遇到的坑_butterknife 错误: 元素值必须为常量表达式-程序员宅基地

文章浏览阅读1.2k次。Android studio中引入butterKnife在build.gradle的ependencies中添加implementation 'com.jakewharton:butterknife:8.5.1'annotationProcessor 'com.jakewharton:butterknife-compiler:8.5.1'接下来在项目中的MainActivity中绑定即可,绑定语句应写在setContentView下面: setContentView(R.layout.activ_butterknife 错误: 元素值必须为常量表达式

Shell编程之case循环、for循环及while循环理论与实例_scl case循环执行-程序员宅基地

文章浏览阅读493次。文章目录前言:一、case多分支语句1.1 case语句的结构1.2 case语句应用示例二、for循环语句2.1 for循环语句结构2.2 for语句应用示例三、while 循环语句3.1 while 语句结构3.2 while 语句应用示例总结:前言:除了我们之前讲述的if条件语句外,作为一种脚本编程语言,Shell同样包含循环、分支等其他程序结构,从而能够轻松完成更加复杂的工作,本篇博客..._scl case循环执行

TCP中的RST标志(Reset)详解_tcp的rst-程序员宅基地

文章浏览阅读2.9k次,点赞2次,收藏7次。TCP中的RST标志(Reset)详解_a_tu_的专栏-程序员宅基地_rst tcp在谈RST攻击前,必须先了解TCP:如何通过三次握手建立TCP连接、四次握手怎样把全双工的连接关闭掉、滑动窗口是怎么传输数据的、TCP的flag标志位里RST在哪些情况下出现。下面我会画一些尽量简化的图来表达清楚上述几点,之后再了解下RST攻击是怎么回事。1、TCP是什么?TCP是在IP网络层之上的传输层协议,用于提供port到port面向连接的可靠的字节流传输。我来用土语解释下上面的几个关键字:por_tcp的rst