0.前言
上一章主要介绍了一些javascript的基础认识,今天主要说一些数据类型的相互转换,以及一些表达式。
1.其它基本类型转换成Number类型-----Number()
<strong>(1)null转换成number类型</strong>
var ret1 = Number(null);
console.log(ret1);//0
console.log(typeof ret1);
拓展:<strong>typeof</strong>是显示变量的属性;格式为typeof 变量名
<strong>(2)undefined转换成Number</strong>
console.log(Number(undefined));
<strong>(3)boolean转换成Number</strong>
console.log(Number(true));//1
console.log(Number(false));//0
<strong>(4)字符串转换成Number</strong>
注意:如果字符串中存在除了数字和点以外的其他字符,则转换失败,值为NaN;加减号在首位置表示正负号;开头有空白字符串可以过滤。如下:
console.log(Number("123"));
console.log(Number("+123"));
console.log(Number("-123"));
console.log(Number(" 123"));
console.log(Number("12.3"));
下面为不能转换的例子:
console.log(Number("12a3"));
console.log(Number("12+3"));
console.log(Number("12-3"));
console.log(Number("a123"));
<strong>特例:打印的值为“0”</strong>
console.log(Number(""));
console.log(Number(" "));
parseInt()和parseFloat()语法
规则:从第一个非空白字符(空格、换行、tab)开始转换,直到遇到一个非数字字符位置,如果转换失败,则打印NaN。
区别:parseInt是将接收到的数据(一般为字符串)转成整数;而parseFloat是将接收到的数据(一般为字符串)转成浮点数。
console.log(parseInt("123"));
console.log(parseInt("+123"));
console.log(parseInt("-123"));
console.log(parseInt(" 123"));
console.log(parseInt("12+3"));
console.log(parseInt("12-3"));
console.log(parseInt("12a3"));
console.log(parseInt("12.3"));
//NaN
console.log(parseInt("a1234"));
//parseFloat()
//将接收到的数据(一般都是字符串)转成浮点数
console.log(parseFloat("12.3"));
console.log(parseFloat(" 12.3"));
console.log(parseFloat("12.3+1234"));
2.其它基本类型转换成字符串类型-----str
<strong>将null转换成字符串</strong>
var str = "Hello world";
console.log(str + null);//null
<strong>将undefined转换成字符串</strong>
console.log(str + undefined);//undefined
<strong>将boolean转换成字符串</strong>
var flag = true;
var ret1 = flag.toString();
console.log(ret1);
console.log(typeof ret1);
<strong>将Number转换成字符串</strong>
var num = 1;
console.log("" + num);
console.log(num.toString());
3.其它基本类型转换成Boolean类型-----Boolean()
注:绝大多数数据转换成boolean结果都为true,除了目前常用的6种值除外。六种值为:
//false
console.log(Boolean(0));
console.log(Boolean(NaN));
console.log(Boolean(""));
console.log(Boolean(false));
console.log(Boolean(undefined));
console.log(Boolean(null));
//true
console.log(Boolean(Infinity));
3.prompt()输入
prompt是进行数据的输入,会在页面提示一个文本输入框,让用户往里面输入数据。但是它接收的数据默认为字符串类型,所以经常和parseInt(),配合使用,将字符串转换成想要的数字。用法如下:
num1 = parseInt(prompt("请输入num1的值"));
num2 = parseInt(prompt("请输入num2的值"));
4.算术运算符合算术运算表达式
表达式:由变量、常量和运算符组成的式子
如何阅读表达式?
(1)功能:进行相关的运算
(2)值:相关运算之后得到的值
算数运算符:+、-、x、、、%(取余)
算术运算表达式的格式:变量1 算术运算符 变量2
功能:进行相关的数学运算,不能改变变量的值
值:相关数学运算后的结果
5.自增自减运算符和自增自减运算表达式
<strong>(1)自增运算符: ++</strong>
自增运算表达式格式:变量++ ++变量
两者都是将变量的值加1,但是两者有分别:
变量++:后加加,先取值再加1,
++变量:前加加,先加1再取值。
var a = 1;
var b;
//b = a++;//1
b = ++a;//2
console.log("a = " + a);
console.log("b = " + b);
可以看到,++a事先将值自加1,然后在赋值给的b,所以a=2,b=2;
<strong>(2)自减运算符: --</strong>
自减运算表达式格式:变量-- --变量
两者都是将变量的值减1,但是两者有分别:
变量--:后减减,先取值再减1,
++变量:前减减,先减1再取值。
var m = 2;
var n;
n = --m;
console.log("m = " + m);
console.log("n = " + n);
6.复合运算符
<strong>+=:</strong>a += 1相当于a = a + 1;
<strong>-=:</strong>a -= 1 相当于a = a - 1;
<strong>*=:</strong>a *= 1 相当于a = a * 1;
<strong>/=:</strong>a /= 1 相当于a = a / 1;
<strong>7.关系运算符和关系运算符表达式</strong>
<strong>关系运算符:</strong>
>:大于;
<:小于;
>=:大于等于;
<=:小于等于;
==:等于;
===:绝对等于;
!=:不等于;
注意:(1)关系运算附不能连用,如
1 <= num <= 5
(2)“==”:知识让数据相等即可,而“===”:数据与类型都要相等,如
var num = 1;
var str = "1";
//数据等于即可
console.log(num == str);
//数据与类型都要相等,
console.log(num === str);
<strong>8.逻辑与、或、非运算符</strong>
<strong>(1)逻辑与:</strong>运算符:&&;
表达式:表达式1 && 表达式2;
值:
如果表达式1的值为真,表达式2的值为真,则逻辑与表达式的值为真
如果表达式1的值为真,表达式2的值为假,则逻辑与表达式的值为假
如果表达式1的值为假,表达式2的值为真,则逻辑与表达式的值为假
如果表达式1的值为假,表达式2的值为假,则逻辑与表达式的值为假
【有一个为假就为假】
if (1 && 2) {
console.log("*************1");
}
if (1 && 0) {
console.log("*************2");
}
if (0 && 2) {
console.log("*************3");
}
if (0 && 0) {
console.log("*************4");
}
<strong>(2)逻辑或:</strong>运算符:||
逻辑或运算表达式: 表达式1 || 表达式2
值:
如果表达式1的值为真,表达式2的值为真,则逻辑或表达式的值为真
如果表达式1的值为真,表达式2的值为假,则逻辑或表达式的值为真
如果表达式1的值为假,表达式2的值为真,则逻辑或表达式的值为真
如果表达式1的值为假,表达式2的值为假,则逻辑或表达式的值为假
【有一个为真就为真】
if (1 || 2) {
console.log("*************1");
}
if (1 || 0) {
console.log("*************2");
}
if (0 || 2) {
console.log("*************3");
}
if (0 || 0) {
console.log("*************4");
}
<strong>(3)逻辑或:</strong>运算符: !
逻辑非运算表达式: !表达式
值:
如果表达式的值为真,则逻辑非运算表达式的值为假
如果表达式的值为假,则逻辑非运算表达式的值为真
【颠倒黑白】
if (!1) {
console.log("********1");
}
if (!0) {
console.log("********2");
}
注意:逻辑与和逻辑或都遵循惰性原则。
<strong>惰性原则(段落原则):</strong>从左至右依次计算表达式的值,直到遇到一个表达式的值为假(真)则停止计算,因为此时我们已经知道逻辑与(逻辑或)运算表达式的值为假(真)了。
<strong>9.总结</strong>
以上只是学习javascript之前所要进行的必须的准备,了解这些,基本上只是刚刚入门,希望对喜欢或者打算要学习的童鞋能够有所帮助,谢谢,打赏!!!!!
网友评论