欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

基于javascript 显式转换与隐式转换(详解)

程序员文章站 2022-05-07 14:08:42
显示转换 1.题目:请输入今年的年龄,求5年后多大? //a.prompt接收到的数据是string类型的。 var age = prompt("请输入你今年...

显示转换

1.题目:请输入今年的年龄,求5年后多大?

//a.prompt接收到的数据是string类型的。
var age = prompt("请输入你今年的年龄");
alert(typeof age);
var age5 = age + 5; // 这里只会拼接成了15,而不是加5
alert("我今年"+age+"岁了,5年后我"+age5+"岁了");

2.字符串要转换成number类型。

针对上述问题,需要将age转换为数字型

2.1 可以使用number(需要转化的内容);

var str = true;
  var num = number(str);
  console.log(num); //1 
  console.log(typeof num); //number
  // 注意:
  // 1.如果这个转换的字符串本身就是一个数字,那么可以转换成功; 如果这个字符串本身不是一个数字,那么转成nan.
  // 2.如果这个字符串本身是一个数字,前后有空格,也是会转换成功的; 如果中间有空格,就转成nan.
  // 3.如果是一个"",或者是" ",或者是flase,那么会转换成0.true转成1,undefined转成nan
  // 4.如果字符串的本身是一个小数,也是可以转换成功的。

2.2 可以使用parseint(需要转化的内容);

var str = "123";
var num = parseint(str);
console.log(num); //123
console.log(typeof num); //number
//  注意:
//  1.从左往右查找,直到遇到第一个非数字为止,前面的所有的内容转换成数字。
//  2.如果找完了,都没有找到一个数字,那么就转换成nan.
//  3."" 和 "  " 转化成nan
//  4.如果字符串里面是小数,那么转换后只能得到他的整数部分。

2.3 可以使用parsefloat(需要转化的内容);

var str = "123.24ll";
var num = parsefloat(str);
console.log(num); //123.24
console.log(typeof num); //number
// 注意:如果字符串里面是小数,那么转换后还是小数。。
//******注意: true会转成1,false会转换0.
// 如果字符串转数字,一般的使用parseint或者parsefolat。
// 如果是其他类型,比如布尔类型,使用number();

3. 其他类型数据 转换成字符串类型。

3.1 可以使用 string(需要转化的内容);

var num = 123;
var str = string(num);
console.log(str); //"123"
console.log(typeof str); //string
//注意: "123"  "true" "false" "undefined"  "null" "nan"

3.2 可以使用 需要转化的内容.tostring();

var num = 123;
var str = num.tostring();
console.log(str); //"123"
console.log(typeof str); //string
//注意: "123"  "true" "false "nan"
//undefined 和null 不能使用tostring。

4.其他的数据类型 转换成 boolean类型。

4.1 可以使用boolean(需要转化的内容);

var num = "";
var res = boolean(num);
console.log(res); //false
console.log(typeof res); //boolean
//注意:
//那些可以转换成布尔类型的false: 0 -0  false "" undefined null nan
//" "会转换成true

隐式转换

1.其他的类型转换成number类型。

1.1 可以在需要转换的内容前面加上正号。 +

var str = "123";
var res = +str;
console.log(res); //123
console.log(typeof res); //number

1.2 可以让需要转换的内容做算术运算不能后面用 +

var str = "123";
var res = str * 1;
console.log(res); //123
console.log(typeof res); //number
//注意: 一定要和连接符做一个区分。

2.其他的类型转换成string类型 。 使用连接符 +“”

var num = 123;
var str = num + "";
console.log(str); //"123"
console.log(typeof str);//string

3.其他的类型转换成boolean类型 。 使用取反运算符

var num = undefined;
var res = !!num;
console.log(res); //false
console.log(typeof res);boolean
// 注意:那些能转成布尔类型的false:0 -0 false undefiend null nan ""

1.题目:请输入今年的年龄,求5年后多大?

//a.prompt接收到的数据是string类型的。
var age = +prompt("请输入你今年的年龄");
var age5 = age + 5;
alert("我今年"+age+"岁了,5年后我"+age5+"岁了");

以上这篇基于javascript 显式转换与隐式转换(详解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。