任务描述
本关任务:在函数 objectTest() 内部定义了六个变量 a、b、c、d、e、f,并已经赋值,你需要判断它们各是什么数据类型。变量 aType、bType、cType、dType、eType、fType 分别表示上面六个变量的数据类型的名字,你需要给他们赋值。比如变量 a 如果是数字类型,需要给变量 aType 赋值字符串 number。可选的数据类型名如下: number、string、bool、object、undefined 和 array 分别表示数字、字符串、布尔型、对象类型、undefined 还有数组。
相关知识
JavaScript 的数据类型有数字、字符串、布尔型、对象类型、数组、null 和 undefined。
数字类型
JavaScript 中的数字类型指整数和浮点数,不刻意区分二者。
JavaScript 还支持16进制的整数,在所要表示的16进制数前面加上 0x 或者 0X 即可,如 0x1f 表示整数31。
对于较大或较小的数,JavaScript 还支持科学记数法,如 2e3 表示2000。
对于一般的数学运算,如加减乘除,和数学上的表达方式相同。对于稍微复杂的运算,需要通过 Math 对象定义的函数来实现,下面是一些例子:
var number1 = 0X11; //17
var number2 = 2.01e-2; //2.01*0.01
var number3 = Math.sqrt(9); //计算9的平方根
字符串
在 JavaScript 中,没有字符的说法,字符看成长度为1的字符串,字符串指包含在单引号或者双引号中的文本。
需要特别注意的是,字符串中的字符不能和外侧的单引号或者双引号构成一个引号对,如果字符串中有引号,需要用转义字符将这些引号变为普通字符,简单来说,转义字符的功能就是使字符串中的字符不被误认为该字符串的结束符号。
如 I'm studying a language,需要用\
把中间的单引号转义:
var tran = 'I\'m studying language';
另外,关于字符串,有很多常用的函数,可参考本实训系列的第九篇实训。
布尔型
布尔型:有两种逻辑状态的类型,它的值只有 true 和 false 两个,分别表示正确、错误。
var boolType1 = true;
var boolType2 = false;
常用在控制结构的不同入口的判断上,如:
if(myNumber == 1) { //myNumber为1则返回true并进入下面的句子
console.log("myNumber值为1");
}
else {
console.log("myNumber值不为1");
}
数组
JavaScript 中的数组是数据的集合,每一个数据在数组中对应一个位置,称为该数据的索引。数据称为数组中的元素,JavaScript 数组中的元素可以是不同的数据类型。
var myArray = [1,2,true,"string",3.2];
上面就定义了一个含有整数、布尔型、字符串、浮点数的数组。 关于数组的内容有很多,详细请参考《JavaScript 学习手册五:JS 数组》。
null 和 undefined
undefined 表示某个变量没有被赋值,比如,变量在申明的时候没有赋值,那么它的值就是 undefined。null 是对象,是一个空的对象引用。
var myVar;
console.log(myVar);
console.log(a);
如上面所示,尝试输出变量 myVar,结果会输出 undefined,因为这个变量只申明,没有赋值。而尝试输出变量a
会产生错误,因为这个变量没有定义,是一个空的对象引用。
对象类型
JavaScript 是面向对象的语言,严格的来说,在 JavaScript 中,一切都可称为对象。但是我们这里介绍的对象仅指键值对的集合,可以类比于 C 中的结构体或者 Java 中的对象。
var student = {
name:"Peter",
age:23,
gender:male}; //申明并初始化对象
console.log(student.name); //输出"Peter"
student.name = "Bob";
console.log(student.name); //输出"Bob"
编程要求
本关的编程任务是补全右侧代码片段中 Begin-End 中的代码,具体要求如下:
在函数 objectTest() 内部定义了六个变量a、b、c、d、e、f,并已经赋值,你需要判断它们各是什么数据类型;
变量 aType、bType、cType、dType、eType、fType 分别表示上面六个变量的数据类型的名字,你需要给他们赋值。比如变量 a 如果是数字类型,需要给变量 aType 赋值字符串 number;
可选的数据类型名如下: number、string、bool、object、undefined 和 array 分别表示数字、字符串、布尔型、对象类型、undefined 还有数组。
本关涉及的代码文件 DataKind.js 的代码框架如下:
function objectTest() {
var a = {name:"myName",id:2};
var b = [1,true,2];
var c = 1;
var d = "1";
var e = true;
var f;
var aType,bType,cType,dType,eType,fType;
//请在此处编写代码
/********** Begin **********/
/********** End **********/
return aType+","+bType+","+cType+","+dType+","+eType+","+fType;
}
测试说明
测试过程:
平台将读取用户补全后的 DataKind.js;
调用其中的 objectTest() 方法;
接着根据 objectTest() 方法的输出判断程序是否正确。
以下是测试样例:
测试输入:
无测试输入
测试输出:
object,array,number,string,bool,undefined
function objectTest() {
var a = {name:"myName",id:2};
var b = [1,true,2];
var c = 1;
var d = "1";
var e = true;
var f;
var aType,bType,cType,dType,eType,fType;
//请在此处编写代码
/********** Begin **********/
aType="object";
bType="array";
cType="number";
dType="string";
eType="bool";
f="undenfined"
/********** End **********/
return aType+","+bType+","+cType+","+dType+","+eType+","+fType;
}
任务描述
数据类型转换是开发过程中最常碰到的问题之一。
本关任务:函数 mainJs() 有三个字符串类型的参数 a、b 和 c,你需要分别把他们转换为整数,整数和小数。
相关知识
在使用 JavaScript 进行的开发过程中,往往会碰到数据类型转换的需求,尤其是数字转字符串和字符串转数字。
例如,在 JavaScript 中,从前端页面获得的值都是字符串类型,包括数字也会被识别为字符串类型,这自然就产生了转换的需求。
字符串转整数
如果你想把一个字符串转换成整数,有两种方式。
parseInt("12");
parseInt("12.2");
parseInt("C",16);
parseInt("12a2");
parseInt("0XC"); //以上均返回数字12
parseInt("a12"); //失败
Number("12"); //返回12
Number("12a2"); //返回NaN
Number(""); //返回0
字符串转小数
与整数相同,字符串转小数也有两种方式:parseFloat() 和 Number()。
parseFloat() 方法只转换到字符串中第一个不是数字的字符为止,当然这个字符不包括第一个小数点。这里有些不好理解,下面用例子解释。
parseFloat("12"); //返回12
parseFloat("12.2a"); //返回12.2
parseFloat("12.2.2"); //返回12.2,第二个小数点会让转换停止
parseFloat(null); //返回0
数字转字符串
toString() 实现一般的数字转字符串,String() 则是强制类型转换。
toString() 括号内有一个可选的参数,指以几进制的形式转换该字符串,如数字12调用 toString(16) 得到的结果就是 C,即12的16进制表示方式。
String() 可以转换 null 和 undefined,而 toString() 不可以。
var myNum = 15;
console.log(myNum.toString()); //输出"15"
console.log(myNum.toString(16)); //输出"F"
console.log(String(myNum)); //输出"15"
布尔型与其他类型的相互转换
布尔型的值只有两个 true 和 false 。转换规则如下:
下面例子中的 Boolean() 方法实现其他的类型转布尔型。
var myBool = ture;
myBool.toString(); //返回"true"
Number(true); //返回1
Boolean("js"); //返回true
Boolean(""); //返回false
注意,上面讲的空字符串是""
,而不是空格字符串" "
,这两个不同,后者双引号之间有一个英文字符的大小的空位,他们转为布尔型的结果不同:
Boolean(""); //返回false
Boolean(" "); //返回true
隐式转换
JavaScript 是一种弱类型语言,不同类型的变量在运算符的作用下会发生类型转换。这个是编译环境下直接进行的,所以叫隐式类型转换。下面是一些转换规则:
+
运算的两个操作数是数字和字符串,数字会被转换为字符串;+
运算的两个操作数是数字和布尔型,布尔型会被转换为数字;+
运算的两个操作数是字符串和布尔型,布尔型会被转换为字符串;编程要求
本关的编程任务是补全右侧代码片段中 Begin-End 中的代码,具体要求如下:
完成函数 mainJs();
把函数三个参数(从左到右)依次转换为整数,整数和小数;
第一个参数既有可能是 12 这种纯整数的字符串形式,也有可能是 12a3 这种含有非数字字符的字符串;
第二个参数是 16 进制数字的字符串形式,如 af2;
第三个参数是纯小数的字符串形式,如 12.2;
具体请参见后续测试样例。
本关涉及的代码文件 DataKindConvert.js 的代码框架如下:
//你需要把字符串args1,args2,args3转换为数字a,b和c.
function mainJs(args1,args2,args3) {
// 请在此处编写代码
/********** Begin **********/
/********** End **********/
return a+b+c;
}
测试说明
测试过程:
平台将读取用户补全后的 DataKindConvert.js;
调用其中的 mainJs() 方法,并输入组测试数据;
接着测试的输出判断程序是否正确。
以下是测试样例:
测试输入:
5a2,1f,6.1
预期输出:
42.1
测试输入:
12.9,1a,3.1
预期输出:
41.1
function mainJs(args1,args2,args3) {
//请在此处编写代码
/********** Begin **********/
var a=parseInt(args1);
var b=parseInt(args2,16);
var c=parseFloat(args3);
/********** End **********/
return a+b+c;
}