0
点赞
收藏
分享

微信扫一扫

js基础1

他说Python 2022-02-09 阅读 80

#1 JavaScript

1.1简介

​ JavaScript是一种具有面向对象能力的、解释型的程序设计语言。更具体一点,它是基于对象和事件驱动并具有相对安全性的客户端脚本语言。它的主要目的是,验证发往服务器端的数据、增加Web互动、加强用户体验度等。

##1.2基本用法

JS需要和HTML一起使用才有效果,我们可以通过直接或间接的方式将JS代码嵌入在HTML页面中。
行内JS:写在标签内部的js代码

<button type="button" onclick="alert('hello world')">按钮</button>

内部JS:定义在script标签内部的js代码(无src)

<button type="button">按钮</button>
<script type="text/javascript">
			alert('helloworld');
</script>

外部JS:单独的is文件,在HTML中通过script标签引入(有src)

<script src="js/js.js" type="text/javascript" charset="utf-8"></script>

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-2gRQez0U-1644419405454)(C:\Users\cxy\AppData\Roaming\Typora\typora-user-images\image-20220209211600375.png)]

#2 基本语法

1.js代码以行为单位,代码从上往下执行,一行一条语句

2.一行中只有一条语句则语句结尾可以不加分号,但是如果一行中有多行语句则结尾必须加分号

2.1变量

变量即一个带名字的用来存储数据的内存空间,数据存储到变量中,也可以从变量中取出数据

2.1.1变量的声明

js是一种弱类型语言,在声明变量时不需要指明数据类型,直接用var修饰符进行声明

//先声明再赋值
var ;
a=10;
//声明的同时赋值
var b=10;

2.1.2变量的注意点

1若只声明而没有赋值,则该变量的值为undefined

2变量要有定义才能使用,容易变量为声明就使用,就是会报错,告诉你变量未定义

3可以在同一条var命令中声明多个变量

4若使用var重新声明一个已经存在的变量,是无效的

5若使用var重新声明一个已经存在的变量且赋值,则会覆盖掉前面的值

6js是一种动态类型、弱类型语言,也就是说,变量的类型没有限制,可以赋予各种类型的值

2.1.3变量提升

js引擎的工作方式是,先解析代码,获取所有被声明的变量,然后再一行一行地运行,这造成的结果就是所有的变量的声明语言,都会被提升到代码的头部,这就叫变量提升

		<script type="text/javascript">
			console.log(flag);
			var flag=100;
		</script>

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6znmksQW-1644419405454)(C:\Users\cxy\AppData\Roaming\Typora\typora-user-images\image-20220209215535668.png)]

注意:变量提升只针对var声明的变量

2.2数据类型

虽说JS是弱类型语言,变量没有类型,但数据本身是有类型的。针对不同的类型,我们可以进行不同的操

Javascript中有6种数据类型,其中有五种简单的数据类型:Undefined、Null、布尔、数值和字符串。一种复杂数据类型 Object

2.2.1undefined

undefined类型的值是undefined

undefined是一个表示“无”的原始值,表示值不存在

出现undefined的常见情况

1.当声明了一个变量而没有初始化是,这个变量的值就是undefined

2.调用函数时,该函数有形参,但未提供实参,则该参数为undefined

3.函数没有返回值时,默认返回undefined

2.2.2null

null类型是只有一个值的数据类型,即特殊的值null。它表示空值,即该处的值现在为空,它表示一个空对象引用

使用null类型值时注意一下几点:

​ 1.使用typeof操作符测试null返回object字符串

​ 2.undefined派生子null,所以等值比较返回值是true,未初始化的变量和赋值为null的变量相等

		<script type="text/javascript">	
			var a=null;
			var b;
			console.log(b==a);
			console.log(typeof a);
		</script>

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-nDUNRA6j-1644419405454)(C:\Users\cxy\AppData\Roaming\Typora\typora-user-images\image-20220209221816488.png)]

2.2.3布尔

布尔类型只有两个值true、false。常用来做判断和循环的条件

2.2.4数值型

数值型包含两种数值:整型和浮点型

​ 1.所有的数字都是以64位浮点数形式存储。所以,js中1与1.0相等,而且1加上1.0得到的还是一个整数。浮点数最高精度是17位小数,由于浮点数运算时可能不精确,尽量不要使用浮点数做判断

​ 2.在存储数值型数据时自动将可以转换为整型的浮点数值转为整型

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aBTbIEiu-1644419405455)(C:\Users\cxy\AppData\Roaming\Typora\typora-user-images\image-20220209222520902.png)]

		<script type="text/javascript">
			console.log(1==1.0);
			var c=1+1.0;
			console.log(c);
			console.log(1.0);
		</script>

2.2.5字符串

使用‘’或“”引起来

使用加号‘+’进行字符串的拼接

2.2.6对象

对象是一组数据和功能的集合

2.3类型转换

2.3.1自动转换

1.所有的值转字符串都是加引号

2.转布尔型:有值为true,无值为false(0为false,非0位true)

3.空值是0,非空的数值型字符串能转换,非数值字符串转换为NaN

2.3.2函数转换

Js提供了 parseInt和 parseFloat(两个全局转換函数。前者把值转换成整数,后者把值转换成浮点数。只有对 String类型调用这些方法,这两个函数才能正确运行;对其他类型返回的都是 NaN(Not a Number )

在转换之前,首先会分析该字符串,判断位置为0处的字符,判断它是否是个有效数字,如果不是,则直接返回NaN,不再继续,如果是则继续,直到找到非字符。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-iTYu41zi-1644419405455)(C:\Users\cxy\AppData\Roaming\Typora\typora-user-images\image-20220209225301417.png)]

			console.log(parseInt("123bule"));
			console.log(parseInt("1.1"));

该方法与 parseInt(方法的处理方式相似,从位置0开始查看每个字符,直到找到第一个非有效的字符为止,然后把该字符之前的字符串转换成数字。不过,对于这个方法来说,第一个出现的小数点是有效字符。如果有两个小数点,第二个小数点将被看作无效的, parseFloat(方法会把这个小数点之前的字符串转换成数字。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-SYy52FCE-1644419405456)(C:\Users\cxy\AppData\Roaming\Typora\typora-user-images\image-20220209225329483.png)]

			console.log(parseFloat("123bule"));
			console.log(parseFloat("123.111bule"));

2.3.3强制转换

几乎每个数对象都提供了 tostring()函数将内容转换为字符串形式,其中 Number提供的 tostring()函数可以将数字转换为字符串Number还提供了 toFixed函数将根据小数点后指定位数将数字转为字符串,四舍五入

注意:值不能为null

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-KvojVRFx-1644419405456)(C:\Users\cxy\AppData\Roaming\Typora\typora-user-images\image-20220209225829887.png)]

			var aa=10;
			var bb;
			console.log(aa);
			console.log(aa.toString());
			console.log(bb.toString());

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-J4Xnzi3r-1644419405457)(C:\Users\cxy\AppData\Roaming\Typora\typora-user-images\image-20220209230122438.png)]

		var cc=1.2345;
		console.log(cc);
		console.log(cc.toFixed(3));

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-QsYfpksy-1644419405457)(C:\Users\cxy\AppData\Roaming\Typora\typora-user-images\image-20220209230518026.png)]

			var d="123";
			var f="123ab";
			console.log(Number(d));
			console.log(Number(f));

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-q03r1qIA-1644419405457)(C:\Users\cxy\AppData\Roaming\Typora\typora-user-images\image-20220209230754352.png)]

			var e="123";
			var g="123ab";
			var j;
			console.log(Boolean(e));
			console.log(Boolean(g));
			console.log(Boolean(j));

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hPC6LcOx-1644419405458)(C:\Users\cxy\AppData\Roaming\Typora\typora-user-images\image-20220209230909411.png)]

aa=10;		
console.log(String(aa));

;
var g=“123ab”;
var j;
console.log(Boolean(e));
console.log(Boolean(g));
console.log(Boolean(j));




> String

[外链图片转存中...(img-hPC6LcOx-1644419405458)]

```js
aa=10;		
console.log(String(aa));
举报

相关推荐

0 条评论